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آلفہےل۔ اإول 
مكونات الأوراكل 


ORACLE ARCHITECTURE 


ORACLE SERVER 


هو نظام لادارة قواعد البيانات و يتكون من مكونيين اساسيين هما : 


ORACLE INSTANCE, ORACLE DATABASE 


: ORACLE INSTANCE 


من أهم مكونات الأوراكل يحتوي عل Memory Structure‏ و .Process structure‏ لتتمکن من 
الوصول الى البيانات "ه٥"‏ يجب أن يكون ال ٥ء«ه)ء.1‏ في وضعية العمل» أي انه يتم من خلاله 
الحصول على البيانات المطلوبةء ولا يستطيع ال مهوم[ فتح و تشغيل أكثر من مءوطه)ه( واحد فقط 
في نفس الوقت» ولكن من الممكن لأكثر من ءء, هوم[ العمل على ذات ال مووطو٤ة0.‏ 


INSTANCE 


Memory Structure 
LE 


Background Processes Structure 


رسم 1.1 


: ORACLE DATABASE 


عبارة عن مجموعة من الملفات لحفظ البيانات واستعادتها عند الطلب وينقسم الى قسمين هما اهءأوما 
Physical structure ڃs structure‏ . 


اما ال هزعم يتكون من أقسام لتخزين وادارة ال مsئةطه†ة0‏ . _ 
اما ال 1وءاورط۴ يتكون من الملفات الحقيقية الموجودة على الكمبيوتر أو السريفر . 


مثال: 


عندما تشاهد صورة على موقع انترنت فإنك تشاهد الجزء ال 1وءاعم] أما الملف الحقيقي للصورة والذي 
مخزن في السيرفر يكون الجزء ال اوور ط٣.‏ يكون هنالك ارتباط بين الجزئين بحيث اذا حذف أحدهما يجب 
حذف الجزء الأخرء اذ لا فائدة من إبقاء ملف الصورة ال 1دوء زور ط۴ في السیرفر اذا كنت لا تريد عرض 
الصورة على الأنترنت. 


: من ثلاث ملفات هي‎ Database physica stu c)u ۲e ویتکون‎ 


ئ 0n t01‏ : ملفات التحكم تحتوي على المعلومات اللازمة للمحافظة على ال مsوطه)04‏ ويجب ان 
يتوفر على الأقل ملف واحد ليعمل .Oracle Database‏ 

6 هD4t:‏ الملفات التي يتم تخزين المعلومات والبيانات داخلها. 

6 ع10 :8e40‏ تقوم بتسجيل جميع المتغيرات التي طرأت على ال مءوطه)ه0 مثل أضافة أو حذف 
بعض البيانات "54a"‏ لنتمكن من استعادة البيانات في حدوث ضياع بيانات بشكل مفاجئ (مثلاً: انقطاع 
التيار الكهربائي قبل حفظ البيانات المتغيرة). 


ویوجد ملفات أخری في ال 1هءiورطم‏ ولکنها لیست ضمن ال 4۲ ط هھ انما ضمن ال .04٤1e $e‏ 
ويجب أن تتواجد لتشغيل واستخدام واغلاق ال مووطو)ه مثل: 


.۴ |۷] الذي یحتوی على المعلومات اللازمة للدخول الی ال مم ه)ءہ] مثل ومعم‎ :Pهssword‎ File 


:Archived Redo Log files‏ عبار ة عن نسخ ل وم۴ و10 8٥0‏ للمزيد من الأمان في حالة حدوث 
أي ضياع للبيانات. 


M+ تخزن المواصفات الخاضة لل مءرو٤ءم! مثلاً حجم الذاكرة الممنوحة لل ر‎ :Parameter File 
ومواصفات أخری نتطرق لھا لاکفا.‎ Structure 


ORACLE SERVER PHYSICAL STRUCTURE 


RACLE DATABASE 


CONTROL FILES 
PARAMETER FILE 
REDO LOG FHLES 
PASSWORD FILE 
DATA FILES 
ARCHIYED LOG FILES 


رسم 1.2 


اما ال Structure‏ اogicaا‏ یتکون من: 

"ab espac5‏ : تنقسم ال 45e‏ طtaهD‏ الی وحدات اصغر تسمی ال 6s‏ ےمء٥1ط۲4.‏ کل ط)4( یجب 
ان يتكون من واحد أو أكثر مء ومءع1ط4٠.‏ يوفر الأوراكل مء4مء٥1ط14‏ ١"٠ءر؟‏ في بداية تكوين ال 
Pte‏ کحد ادني ضروري لعمل ال مو طه)ه(. 

:Segments‏ ينقسم ال ce‏ 2م1esط‏ ۲4 الی وحدات أصغر تسمی ال 4۶م" عم؟. 

.E×)eہ‎ ٤ی ینقسم ال ٤ر٥۸ nعەS الی وحدات اصغر تسمی ال‎ :Extent 


TO 


10ekاB:‏ تنقسم ال E×)٥1٤‏ الى وحدات أصغر تسمى ال ءء810 وهي أصغر وحدات تخزين و قراءة 
البيانات. 


سوف يتم التطرق احقاً بالتفاصيل في الكتاب لمكونات ال S0 ı1e‏ |ھicوLo.‏ 


DATABASE LOGICAL STRUCTURE 


DATABASE 


TABLESPACE 
SEGMENTS 


EXTENTS 


BLOCKS 


رسم 1.3 


ORACLE MEMORY STRUCTURE 


يتكون من منطقتين تعرفان باسم : 


:System Global Area (SGA)‏ وهي Memory structure Û|‏ الخاص بال ce‏ رھtیہا‏ الذي تم 

التحدث عنه مسبقاً (راجع الرسم 1.1) والتي هي أحد أهم مكونات ال مم )وم1 وتحجز المساحة الخاصة لها 
من الذاكرة (أو تبداً بالعمل) عند تشغيل ال مء« ه٤ء.[.‏ وهي ذاكرة مشتركة بین الأوامر "۴٣٥٤۲٤٤٥"‏ التي 
تأتي لل عد ھtیہ]‏ مثل وی۴06 5Q1 Query‏ وايضاً مشتركة بين مستخدمي ال یو ط ھ٤54‏ 
المختلفين» وتعرف ايض ڊسم : .Shared Global Area‏ 


Glob Area (PGA)‏ r0gramاP:‏ وهي المساحة المخصصة من الذاکرة ل ۴٣٤٣۶‏ ٣٥ل‏ وتحتوي 
على معلومات حول ال ۴۲۵٤6۶‏ ۲۷۵۲٥؟.‏ وهي ذاكرة خاصة لأمر ''وومع "٣٥‏ واحد فقط, 
وتعرف ايضÎ‏ ڊlصم‏ : Process Global Area gi Private Global] Area‏ . 


„Server Process y User Process J سوف يتم التطرق اح‎ 


ûracle Memory Strcuture 


SGA 


ذاگرة مشت ك 


رسم 1.4 


SYSTEM GLOBAL AREA (SGA) 


جميع مستخدمي ال م4طهه( يتشاركون البيانات الموجودة في هذه المنطقة حيث يتم تخزين البيانات 
المشتركة من مختلف الأوامر "ءعءءء١٠إ۴‏ مءدطه)٤4٥"‏ لكي تسهل عملية استخراج البيانات . يقوم ال 
ماءها0 بحجز المساحة المخصصة له من الذاكرة عند بداية تشغيل ال مء« وء[ ويقوم بتحرير المساحة 
عند انهاء عمل ال مر و٤ء"1ء‏ وتقسم الى عدة أقسام منها أقسام اساسية ضرورية ومنها أقسام اختيارية. 


الرسم رقم 1.5 يوضح الأقسام الاساسية والأقسام الاختيارية (الأقسام الاختيارية باللون الاحمر)» وسوف يتم 


SHARED POOL 
AREA 


OTHER MEMORY 
STUCTURES 


رسم 1.5 


تعتبر ال 96۸ ذاكرة مرنة دايناميكية أي ان باستطاعة أقسامها ان تكبر أو تصغر في الحجم دون أغلاق ال 
معnهnstا‏ لأسباب مختلفة مثل كثرة العمل ( كثرة الأوامر) على أحد أقسامها اذ أن زيادة العمل على احد 
الأقسام يتتطلب ذاكرة اضافية ولكن لا يمكن للذاكرة العامة لل 564 ان تتخطى الحد الأعلى المحدد بالعامل 
.SGA_MAX SIZE "Parameter"‏ 


ملاحظة:S178_×‏ 86۸_۷۸4 هي احد مکونات اJÛ nti اization Parameter File‏ التي سوف یتم 
التطرق لها لاحقاً. 


تذکر: ال ۴1٥‏ ماص ه۲ ه۴ التي جاء ذكرها قبل قلیل. 

مثال تطبيقي 1.1: 

لمعرفة حجم ال 56۸ الحالي اكتب التالي في برنامج 8ا1۲ :5SQ‏ 
SHOW SGA;‏ 


ال System Global Area‏ |7014 تمثل حجم ال $6۸ الحالي. 


مثال: 


اذا كانت الذاكرة المخصصة لل 564 حوالي 100 ميغا بايت والتي تعتبر "S6۸_۷۸× _ S17۳"‏ وكان 
التوزيع المبدني للذاكرة على الأقسام المختلفة على النحو التالي: 
=Shared Pool Area‏ 50 میغا بایت 
=Database Buffer Cache‏ 25 میغا بایت 
-R ed0 Log Buffer‏ 10 ميغا بايت (منطقة ثابتة غير متغيرة) 
باقي الأقسام = 15 ميغا بايت. (الأقسام المتغيرة) 
الذاكرة الكاملة = 100 ميغا بايت 


وزاد ضغط العمل علی $4۲٥4 ۲٠۵1 ۸۲٥4‏ بحيث أن 50 میغا بايت لم تعد تكفي» فبمقدور S4۲٥4‏ 
4 ۴01 بان تأخذ ذاكرة اضافية من باقي الأقسام ولكن لا يمكن للذاكرة الكاملة بأن تزيد عن 100 ميغا 


بایت. 
باي 


=Shared Pool Area‏ 60 میغا بایت 

=Database Buffer Cache‏ 20 میغا بایت 

Buffer‏ ع0ا 10-R ed0‏ ميغا بايت (منطقة ثابتة غير متغيرة) 
باقي الأقسام = 10 ميغا بايت (الأقسام المتغيرة) 

الذاكرة الكاملة = 100 ميغا بايت 


الذاكرة في ال 56۸ عبارة عن وحدات متواضلة تسمی sءءاںuرھاG‏ وحجم ال eاuروإی‏ يعتمد على 
.SGA_MAX_SIZE‏ 


SE‏ _ )56۸_۷1۸ أصغر من 128 میغا بایت, اذا حجم کل eآںم‏ هی يساوي 4 میغا بایت آما اذا کان 
حجم ال S17۴‏ )56۸_۷1۸ اکبر من 128 میغا بایت اذارحجم کل eاںu‏ "ه6۲ يساوي 16 میغا بایت. 


الحد الأدني من عدد ال وماu‏ موی لل 56۸ هو ثلاث. 
واحد مام واي للمنطقة الثابتة في Redo Log Buffer Jû SGA‏ 
y|>ذ Shared Pool Area Û Granule‏ 


Database Buffer Cache Û Granule ذ>|y‎ 


ملاحظة: يمكن الحصول عن بيانات عن .VSBUFFER_POOLje Granules ÛJI‏ 
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:SHARED POOL AREA 


تستخدم لحفظ أخر أو أحدث أوامر ال SQ‏ و ۴1/5@1 وأخر البيانات(المعلومات) المستخرجة من ال 
.Data Dictionary‏ تتكون من قسمين .Data Dictionary Cache s Library Caclıe : lak‏ 


DATABASE BUFFER SHARED POOL 
CACHE AREA 
LIBRARY LAL HE. 


FOF 
REDD LUI BUFFER SAL-FLUSAL 


GATA DICTIONARY 
A HEFOR DATA, 
DICTIONARY 
LARGE FOOL INFORMA TION 


OTHER MEMORY 
E STUCTURES 


ربنم 1.6 


باعتبارها منطقة مهمه جداً فمن الممكن تغير حجمها دايثاميكياً (بدون اغلاق ال مء« ه)ءم]) بحيث لا 
يتجاوزالزيادة فى المساحة مساحة ال 96۸ المحددہ بالعامJ .SGA_MAX SIZE "Paranîe(er'‏ 
يعتبر حجم ال SHARED POOL ARÊ^‏ محددة من قبل الخال "۲ء)e "Para‏ 

SHARED_POOL_ SIZE 


مثال تطبيقي1.2: 


لمعرفة الحجم الحالي ل ۴٠١1 ۸۲١4‏ Q١إهط؟‏ اكتب التالي: 

SHOW PARAMETER SHARED POOL SIZE; 

في الكمبيوتر الخاص بي الحجم هو : 46 18 و يظهر كالتالي = 46137344 
لتغيير مساحة ال ۴٠١1 ۸۲٠‏ ۲4ط دايناميكياً اكتب التالي: 

ALTER SYSTEM SET SHARED POOL _SIZE= 64M; 
„System altered: SQL PLUS ja في حالة نجاح الأمر يظهر الجواب التالي‎ 


أما في حالة عدم وجود ذاكرة أضافية لان تضاف ل ۴٣١1 ۸۲٥۸‏ 4٥4۲طS؟‏ يظھر الجواب 
التlئي .Insufficient memory 1o grow.‏ 
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:Library Cache 
: تحتوي على‎ 


SQL Shared Statements :1 المنطقة رھم‎ - 
PL/SQL Procedures or Packages: 2 المنطقة رقم‎ - 
مثال:‎ 

عندما يقوم مستخدم لل مهه( بطلب جملة ال 5Q1‏ فإن الجملة وطريقة انجاز مهامها تخزن في 
المنطقة رقم 1 وبذلك يسهل عملية تكرار انجاز ٤٥"‏ uءء×٤"‏ ال 5Q1‏ من الذاكرة بسرعة أكبر في حال تم 
طلب نفس الجملة من مستخدم أخر ويذلك تكون العملية أسرع وتخفف العبئ على ما يعرف باسم 
ationsا€0mpi»‏ وكذلك ینطبق الحال على .۴1/8Q1‏ 


خطوات عملية: 


الخطوة 1: يقوم المستخدم الأول بطلب جملة ال 9Q‏ التالية : ;وeمرl0اemp select * from‏ 

الخطوة 2 : يقوم ال كومءهإ۴ إم۷إم$ بدراسة الجملة ومعرفة المراحل التي سوف يتم بعدها 
انجاز""م٤ںءم×>5"‏ الجملة على اعتبار أن هذه الجملة ليست مخزنة في ال مد٣‏ ر٣4إطاا.‏ 

الخطوة 3: يتم تخزين الجملة ومراحل انجالها في ط4٣‏ ر٣4إطاا.‏ 

الخطوة 4: يتم اظهار البيانات الناتجةرهن”جملةال 9Q1‏ للمستخدم الأول وبذلك تكون جملة ال SQ‏ تم 
انجازها وتم تسجيل جميع المراحل التي زت بهاا'الجملة في ال ط4٣‏ رإ4إطا. 

الخطوة 5: يقوم المستخدم الثاني بعد قليل بگثابة نفس جملة ال SQ1‏ وهي select * from employees;‏ 
الخطوة 6: يقوم ال ۴٣٠٤٤5‏ ٣۷م‏ بدراسةرالجملة فيجد انها موجوده في ال ط٥4٣‏ yاھإط1]‏ فینفذ 
مراحل انجاز الجملة دون دراسة الجملة باعتبار ان المراجل التي تمت لانجاز الجملة مخزنة في ذاكرة ال 
.Library Cache‏ 

الخطوة 7: يتم اظهار البيانات المطلوبة للمستخدم الثاني بسرعة أكبز. 


:Data Dictionary Cache 


المكون الثاني ٺل 4 PO01 ۸R‏ AREDګSH‏ والتي يحتوي على بيانات Data Dictionary Û ja‏ 
حول: ables, ndexes, Privileges, ec...‏ . وهي تعمل بنفس طریقۂ ال eطc‏ €2 Library‏ . 


وعندما تمتلئٰ منطفَة rary Cae‏ ط1 أو Data Dictionary Cache‏ یقوم الأوراکل باخراج أقدم 
بيانات لم يتم تكرار طلبها لتعوض ببيانات جديدة وتعرف الطريق بlسصم: Least Recently Used (LRÛ)‏ 
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:DATABASE BUFFER CACHE 


يتم تخزين فيها أحدث البيانات التى تم استخراجها من الملفات الفيزيائية "ء٥۴1‏ و)54" » وفي حالة طلب 
ذات البيانات من ذات المستخدم أو من مستخدمين أخريين لل مsوطهه‏ يتم استخراج البيانات من الذاكرة 
ولیس من ۴1٥۶‏ 04)4. 


.Least Recently Used (LRÛ) pIظنب ملاحظة: تتم ادارتھا ايضاً‎ 


مثال: 
عندما يقوم مستخدم لل مءوطه)هD‏ بطلب بيانات محددة من ال مووطه)ه0 عن طريق مثلاً جملة ال 1اSQ؟‏ 
فإن البيانات المستخرجة من ال وم۴1 و٤4(‏ تخزن في ال eطac€ Database Buffer‏ وبذلك یسھل 
عملية استخراج البيانات وبسرعة أكبر في حال تم طلب نفس الجملة من ذات المستخدم أو مستخدم أخر وبذلك 
يخف العبئ على ما يعرف باصم .Input/Output Load‏ 


راجع الرسم 1.7 لمزيد من التوضيح. 
الخطوات المبينة على الرسم 1.7: 


الخطوة 1: يقوم المستخدم الأول بطلبج يانات ”من المووطو)ة0 . 

الخطوة 2: یقوم ال ٤٤٥۲م 6٥٣۷٥۲‏ بدراسڈة الطلب ویحضر ال ۴٣٣٤٤۶۶‏ ٣م‏ ۷م البیانات من 
الواذ۴ )04 على اعتبار أن هذه البيانات"القطلوبة ليست مخزنة في .Database Buffer Cache J|‏ 
الخطوة 3: یتم احضار البیانات من ال یم۴1 و4 وتخزن البیانات في .Database Buffer Cache‏ 
الخطوة 4: يتم اظهار البيانات المطلوبة للمستخدم الأول. 

الخطوة 5: يقوم مستخدم أخر بعد قليل بطلب ذات البياناك من ال مووطو)ة0. 

الخطوة 6: يقوم ال مء و٤ء.]‏ بدراسة الطلب فيجد ان البيانات المطلوبة تم استخراجها قبل قليل من ال 
ئ ta‏ ومازالت مخزنة في ال ae Buffer €ac†e‏ ظوDat‏ فیستخرج البيانات من ذاكرة ال 
Database Buffer Cache‏ دون الحاجة الى استخراج البیاناتمن القرص الطلب حيث توجد ملفات 
6 هtه0/‏ ومن ثم يتم اظهار البيانات للمستخدم الثاي بسرعة أكب وجهد أقل. 


وتتكون ال Database Buffer Cache‏ من ثلاثة أجزاء مستقلة تسمى :Sub Cache‏ 


)اه ءط: يخزن في هذا القسم البيانات التي ليست من ضمن الأقسام الأخرى (ءاءرءءR‏ ,م٠)).‏ ويتحكم 
بمساحتlq .DB_CACHE SIZE "Parameter'"" Jalil‏ 


م٥٥‏ [: تحافظ على البيانات المخزنة ولا تستبدل» ويتحكم بمساحتها العامل "إم)مر 4٣و۲"‏ 
.DB_KEEP CACHE SIZE‏ 


:Recycle‏ يتم ازالة البيانات من هذه المنطقة عند عدم الحاجة اليها مجدداًء ويتحكم بمساحتها العامل 
.DB_RECYCLE_CACHE_ SIZE "Parameter"‏ 


ملاحظة: مساحة ال )اده لا يمكن أن تكون ان تساوي صفر أبداً. 
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SHARED POOL 
AREA 
LIBRARY CACHE 
FOR 
SAL-PLSOL 


DATABASE BUFFER 


REOD LOG BUFFER 


LARGE FOOL 


| ا۴00 رل 


DATA DIC TID HARTY 
LALCHE FOR DATA 
DICTIONARY 


INFORMATION 


OTHER MEMORY 
STUCTURES 


HARD DISK 
DATA FILES 


رسم 1.7 


مثال تطبيقي 1.3: 


لمعرفة أحجام أقسام ال Database Buffer ٥٣4e‏ اکتب التالي: 
SHOW PARAMETER DB_CACHE SIZE;‏ 


لتغيير مساحة ال eطc Database Buffer ٤a‏ داینامیکیاً اکتب التالي: 


ALTER SYSTEM SET DB_CACHE _SIZE= 30 M; 


:Data Block and Data Buffer 
البيانات المخزنة في ملفات الأوراكل تكون مخزنة نة بشكل كتل ولذلك يطلق عليها اسم وockاB أما البیانات‎ 


المخزنة في ال Database Buffer Cache‏ فتعرف باسم ata Buffer‏ 0. وحجم ال Buffer‏ هو نفسه 
حجم م81 والمحدد ڊdlعامJ .DB_ BLOCK SIZE "Parameter"‏ 


:Data Buffer Advisory Parameter (DB CACHE ADVICE) 


يساعد مدير البيانات (08۸) على ادارةال Database Buffer Cac‏ وخاصة في أوقات الذروة حيث 
يقوم باظهار احصائیات ومعلومات عن مختlلفةJly Database buffer cache‏ . 

يمكن الحصول على البيانات التي ينتجها الئعامd .VŞSDB_CACHE ADVICE je "Para metef"‏ 
وله ثلاث حالات هي: 

:OFF‏ لا يوجد مساحة في الذاكرة مخصصة له وبالتالي لا تقوم بتكوين آي بیانات 

:0N‏ یقوم بتکوین البيانات وله مساحة مخصصة في الذاكرة. 

:READY‏ يوجد مساحة في الذاكرة مخصصة له ولكنه في وضعية الاستعداد ولا يقوم بتكوين اي بيانات. 
ربما تتسائل لماذا اذاً توجد الحالة ۸5۷ ۸R‏ لماذا لم بتم الاكتفاء بأول حالتيين فقط؟ 

الجواب على ذلك يكمن في ان انتقال العامل "۲ء٤٥‏ ۲4و۴" من وضعية ال 0۴۳۴ الى 0١‏ قد يؤدي الى 
أخطاء في الذاكرة أو فشل عملية التحويل. 

مثال تطبيقي 1.4: 


لمعرفة الوضع الحالي اكتب التالي: 
SHOW PARAMETER DB CACHE ADVICE;‏ 


: داینامیکیاً بکتابة‎ D(B_CACHE_ADVICE "Para mee" يمكن تغيير وضيعة العامل‎ 
ALTER SYSTEM SET DB_ CACHE ADVICE = READY; 


ملاحظة: قد تفشل المحاولة اذا كان الوضع الابتدائي 0۴۴. 
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:REDO LOG BUFFER 
من أهم اسس حماية البيانات اذ تحتوي على بيانات عن جميع المتغيرات التي طرأت على ال مووطه)ه0 مثل‎ 
.INSERT,DELETE,ALTER,DROP, CREATE التغيرات الناتجه عj ومر‎ 


المتغيرات التي حدثت في ال مووط دخو تسجل في .Redo Entries pwlڊ Redo Log Buffer J|‏ 
مساح Redo og Buffer J|‏ محددة من قبل اlرامJ .LOG_BUFFER "Parae(er"‏ 


مثال تطبيقي 1.5: 


لمعرفة الحجم الحالي اكتب التالي: 
SHOW PARAMETER LOG_BUFFER;‏ 


لا يمكن تغيير وضيعة العامل 106G_ BUFFER "Para 1)٥۲"‏ داینامیکیا. 


تذکر: ان Buf]‏ و0[ Red0‏ منطقة ثابتة غير متغيرة. 
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:LARGE POOL 


هي منطقة ذاكرة اختيارية وليست اساسية (اجبارية) يمكن لل 084 ان يقوم بتشكيلها حين الحاجة اليها حيث 
توفر ذاكرة كبيرة لعمليات عديدة .BACKUP and RESTORE Jû‏ 


ملاحظات: 

1- علمية ال 8۸4٤0)‏ هي العملية التي يقوم فيها ال 084 بحفظ نسخ "زمه" من البيانات غالبا 
على أقراص صلبة ءال 11۲١‏ لكي يتمكن من المحافظة على البيانات واسترجاعھا RESTORE‏ عند 
الحاجة. 

2- ال Large P٥01‏ لا تعمل بنظام ال U‏ _. 

3- مساحة ال ۴001 معو[ محددة من قبل عامل .LARGE_POOL SIZE "Parameter"‏ 


4- يمكن تغير المساحة دايناميكاً باستخدام A1 ٤R S¥S1 ٤M‏ كما عو الحال مع Shared Pool J|‏ 
وغیرها. 


5- تعمل ال ۴001 مھ[ فقط في بیئة .Shared Server J|‏ 


سوف يتم التطرق لاح „Shared Server J‏ 


:JAVA POOL 
أو‎ 8Q1 هي منطقة ذاكرة اختيارية اخرى توفر ذاكرة لعمليات ال y4وال المختلفة وتعمل بنفس فكرة ال‎ 


اP/Q1‏ في ال ۴001 aedطS»‏ مساحة ال va ۴٠01‏ و[#متحكمة من قبل العامل 
.JAVA POOL_SIZE "Parameter"‏ 
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CONNECTION 


لكي تستطيع الدخول الى ال مءوطهه للقيام بعلميات مختلفة مثل استخراج بيانات عبر جمل ال 8Q1‏ › 
يجب أولاً ان يكون المستخدم متصلاً بال م وا؟ہ1. 

يقوم المستخدم باستخدام أحد البرامج التي يمكن عبرها الاتصال بال مم ه)وم] مثل 5Q ۲0S‏ فينشئ ما 
یعرف باسم ۴۲٥٤6٤۶‏ ۲عءNآ.‏ وبعد ان یتم الدخول الى ال إم۷امS‏ مآء إ0 ویتم الاتصال بال Insta ce‏ 
ینشئ ما یعرف باسم ۴٥٤6۶۶‏ ام۷ مS.‏ یقوم ال ۴٥٤٤5۶‏ إم۷امS‏ بعملیة الوسیط بین المستخدم میا 
r0‏ وال معnstan]‏ حيث يقوم بتنفيذ العمليات التي طلبها المستخدم مثل جمل ال اSQ.‏ 


connection 


GÛatabase User ORACLE SERVER 
1.8 رسم‎ 


:Process 


تعريف ال ۴۲٠٤٠۶١‏ بشكل عام في الأوراكل هي العملية أو الوظيفة التي تنفذ مجموعة من الخطوات أو 
مهمات محددة. 


يوجد ثلاث أنواع من ال وعءوم ۴۲٥‏ في الأورIکJ‏ ھم: User Process , Server Process,‏ 
.Background Process‏ 


. Background Process J aح¥ سوف يتم التطرق‎ 


:Session 


ال رهوومS‏ هو حالة الاتصال الموجودة بين المستخدم و ال إم۷مS‏ ماءوإ0. يبدأ ال رمزوومS‏ عند دخول 
المستخدم ال Se‏ ما0 وینتهي عند خروج المستخدم من ال S٥۷‏ ٥[cھإ0‏ سواء بإرادة 
المستخدم (عند انتهاء المهمة) أو لا ارادياً (عند حدوث عطل ما). 

يمكن للمستخدم الواحد اين يكوّن أكثر من «هاووم؟ واحد في نفس الوقت اذا استخدم أكثر من برنامج مثل 
SQL PLUS‏ و ORACLE FORMS‏ عدا بعض الحالات القليلة. 
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:PROCESSING A STATEMENT (DML) 
ملخصة في الخطوات التالية:‎ )(M1- (جمل ال‎ SQ الخطوات التي تمر عبرها جمل ال‎ 
.Server Process sg User Process jùıyكiy‎ Instance Jlب يتم الاتصال‎ 


اذا كانت البيانات المطلوبة غير متوفرة في Database Buffer Cache J|‏ يم Server J|‏ 
Pr cs‏ باحضار البیانات من ۴٥۶‏ 4)4 0. 


يقوم ال ۴٥٤6s‏ rمrvمS‏ بوضع قیود "ء)٥‏ 10" على البيانات التي یتم تعدیلهاء ویتم تخزين 
البيانات السابقة (قبل التعديل) في منطقة تسى ROLLBACK (SEGMENT) BLOCK‏ 
حتى يستطيع المستخدم باسترجاع البيانات الأصلية غير المعدلة اذا تم اختيار وط[1هR‏ عوضاً 
zEۍù .Commit‏ 


. فإن البيانات المعدلة يتم نقلها الى وم۴1 و)0‎ K٠ ص٤ اذا تم اختيار‎ ٠ 
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PROGRAM GLOBAL AREA (PGA) 


هي منطقة ذاكرة غير مشتركة و خاصة لعملية واحدة فقط "ع٥۲۵‏ ". تخصص ذاکرة ال P6۸‏ لكل 
عملیة ۴۲٥٤۲٣٣۶"‏ " عند بداية العملية ۴٣٠٤٤"‏ " و تزال ذاكرة ال ۴6۸ عند نهاية العملية 
"ءا " . وتحتوي ذاکرة ال P6۸‏ على البيانات الخاصة لتلك العملیة ۰'۴٣ ٥٤٥"‏ مکونات ال ۲6۸ 
تعتمد على تعریف ال إع۷مS؟‏ حیث يوجد تعریفان .Shareds Dedicated la‏ 

في نظام ال Dedic4)e4 Server‏ یتکون Serer ۴٣٥٤٤۶‏ واحد خاص لطلبات ۲۴٥٤٤١۶‏ ٣م‏ ءل واحد 
(مستخدم واحد)» أما في ال ۷م ۵٥۲هط؟‏ فیتم المشاركة في ال $٥۷٥٣ ۴٣٣٤٤5‏ من قبل آکثر من 
€ser Process‏ (یمکن ان یکون هناك آکثر من ۲۲۵٣٤۲٤٤۶6‏ إم۷إم$ و ليس بالضرورة واحد فقط أي مثلاً 
یمکن ان یوجد خمسة وموو ع٤٥٣۴‏ ۲م ۷م یتشارك بھم خمسین مستخدم ومء ع٥0٣۴‏ مء €) 


:۲۴6G۸ بعض مکونات ال‎ 
يحتوي على الأوامر التالية:‎ ۴٣٠٤٤55 حیث تخصص لأي طلب من قبل ال‎ :S0 R1 AREA 
Union, Minus, Ja Set Operators JI Î Distinct , Order By, Group By, 


.Intersect 


:SE10N FORMATION *‏ حیث تخصص لمعلومات المستخدم مثل ال rمeیل‏ 
.Privileges‏ 
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BACKGROUND PROCESSES 


تکون ال Ba ckع ٥u” ۴۲٥٤٤565‏ متوفرة وجاھزة للعمل بعد تشغیل ال ce‏ وtیہ].‏ 
کل Background P٥65‏ مسؤول عن مهمات خاصة» ویوجد نوعیین من dہu٥اع8ack‏ 
۴‰ هما آختیاری و إلزامي ( او إجباري). 


تذكر: الرسم رقم 1.1 ومكان وجود .Background Pإ0cesses JI‏ 


Database Writer (DBWn) 
Log Writer (LGWR) 
System Monitor (SMON) 
Process Monitor (PMON) 
Checkpoint (CKPT) 
Archiver (ARCn) 
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:DATABASE WRITER (DBWn) 


يقوم بكتابة البيانات اnlتغيرة Data JI gli Database Buffer Cache JI ùa "Dirty Buffers"‏ 
۴ كما هو موضح بالرسم 1.9 وبذلك يتم تفرغة ءإم]fں‏ باستمرار من أجل البيانات المتغيرة اللاحقة. 
تذكر: أن البيانات المخزنة في ال ce‏ ھtوہ]‏ تسمی وإم]fں8‏ والبيانات المخزنة في ال وم1از۴ 54٤a‏ تسمیى 

.Blocks 


وتعمل ال ر (8W‏ عند حدوث أحد الأحداث التالية: 


.Checkpoint ùدوح‎ دiع‎ 

عدد ال Dirty Buffers‏ (أو ال Buff‏ الممتلئة بالبيانات المتغيرة) يصل الى الحد الأعلى 
المسموح فيه. 

عند عدم وجود من '١۲عffں8 "۴٣٥۵‏ فارغة بعد البحث عنها من قبل ال ۲۲٥٤65۶‏ . 

٠‏ عند وضع مءaمءء1طه1‏ سواء من النوع العادي أو المؤقت في حالة الإغلاق "ءمذا؟؟0". 

٠ه‏ عند وضع espaceاab‏ 1 في حالة القراءة فقط (اي لا يمکن تغيير البيانات بل فقط الاطلاع 
."Read Only" (lle‏ 

.Backup Û عند وضع ء-ومء٥1طه في حال‎ ٠ 

عند استخدام أوامر Dp‏ و ٥٤ھcہں۲۲‏ الخاصة بال ۲[ط۸۵٠.‏ 

.T¡» e0 u) عند حدوث‎ 


. Tablespacè.di sC eckpoi1 Û سوف يتم التطرق ¥احقً‎ 


ÛLATABASE 


Control Redo Log 


1 


DATABASE BUFFER 
CACHE REDG Lût BUFFER 


SHARED POOL OTHER MEMORY 
AREA STUCTURES 


INSTANCE 
1.9 الرسم‎ 
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:LOG WRITER (LGWR) 


يقوم بنقل البيانات المخزنة في ال eإac٥ 10g Buffer‏ الى ال Redo [0g ۴¡16s‏ بشكل دوري مما 
يساعد على اخلاء ذاكرة لل وم)٤م ٤‏ مل ء8 الجديدة › كما هو موضح بالرسم 1.10. 


تذكر: أن البيانات المخزنة في .Redo Entries amî Redo Log Buffer Û|‏ 
وتعمل ال ۷R‏ 16 عند حدوث أحد الأحداث التالية: 


.Redo Log Buffer J| ùئû عند امتلاءٍ‎ 

عند وجود بیانات في ال R ed0 0g Buffer‏ حجمھها اکبر من M8‏ 1. 
قبل ان تقوم ال ى D(8‏ بنقل البيانات Data Files JI ll Database Buffer Cache J| ja‏ . 
کل 3 ثوان. 

.Transaction Commit his 


DATABASE 


Control Redo Log 
Data Files 


INSTANCE 
1.10 الرسم‎ 
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:SYSTEM MONITOR (SMON) 


في حالة حدوث اي عطل مفاجئ لل مرواو[ جميع البيانات الموجودة في ال ٥٤وہ‏ (مثل بيانات ال 
(Database Buffer Cache‏ التي لم یتم نقلھا الی ال ی۴1۲ و)5a‏ على القرص الصلب تضيع أو تمسح. 
بعد هذه الحالة من ضياع بيانات ال مم ووم يعمل ال ۸ 0 ]$9۷ بشكل اتوماتيكي لاسترجاع بیانات ال 
Instance‏ و تس Ûlعl‏ پ .Instance Recovery‏ 


ويقوم ال 510١‏ بتأدية عدد من الوظائف هي: 


٠ه‏ استرجاع البيانات المتغيرة التي تم تسجيل ما طراً عليها من تغیر في ال ۴1٥s‏ ع10 8e٥‏ ولکن لم 
یتم تسجیلها في ال و۴16 و٤04.‏ حیث قوم ال ×90 بقراءة ال 6sا¡۴ 8R ed0 10g‏ و معرفة 
التغيرات التي طرأت على البيانات و تغيير البيانات في ال 6ذ۴ و٤0a.‏ 

. اعادة تجهيز ال مءوطه)ه ليتمكن المستخدم من الدخول مجدداً‎ ٠ 

ه٠‏ الغاء جميع ال ورمذاووم وآ التي لم يحدث لها انمه وازالة القيود عن البيانات " و54 
"Lock‏ . 

.Da)a ۴ ¡[es واستعادة مساحتها الی ال‎ remporary Seg me ٤s تحریر ال‎ ٠ 

ه جمع المساحات الخالية الصغيرة الضائعة التي تنشىئ بين البيانات نتيجة للتغيرات التي تحدث و 
تعيدها الى المساحة الخالية الرئيسية. 


تذکر: أن ال 16۷۴ یعمل قبل ال W۷‏ 58. 


سوف يتم التطرق لاحقا في الفصول الال لل Temp0r2ry Segê]‏ . 


:PROCESS MONITOR (PMON) 


في حالة حدوث أي عطل لل ءء٥٣٠۴‏ قد يؤدي الى مشاكللداخلية في ال مو ط هه( فیقوم ال PMO‏ 
بتنظیف أخطاء ال .۴٣٥٤ 6٤56s‏ 


ويقوم ال P10١‏ بتأدية عدد من الوظائف هي: 
تحریر کل المصادر وال وم1 علی ال وم1 ط ه۲ أو ال 8٥s‏ التي وضعها ال P٣٥۲ ٤۶۶‏ الفاشل. 


اعادة (ackط11اRo)‏ ال ansactionا"‏ الخاص بالمستخدم (اي الغاء اي تعديلات لم يتم حدوث 
(lj Commit‏ 
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:CHECKPOINT (CKPT) 


ال ٤"زهمckعCh‏ هي عملية كتابة جميع البيانات المتغيرة في Data JI ll Database Buffer Cache‏ 
۴6s‏ عبر ال و .D8 W‏ من فوائد ال ٤«ذهم‌اعمط)‏ ان البيانات التي تتغیر باستمرار تنقل بشكل نظامي و 
دوري الى ال ۴16١‏ وه( وبذلك يتم حفظ البيانات بشكل أمن. 

.Control Files JI y Data Files Header JI "Update" ڊتجديد‎ pgs Checkpoint Process ÛJI 


من البيانات التي تجدد ")ولم لا" : 

.Data Files Header JI „ê Checkpoint J| رم‎ 
.Control Files JI a Checkpoint ÛJI رم‎ 
.Control Files ÛI ي‎ Log Sequence J| رم‎ 
.Control Files JI aê SCN ÛJI 

„Archived Log Û| slaw 


SCN Jigs Log Sequence JI s Data Files Header Ji سوف يتم التطرق لاحقا في الفصول التي‎ 
«Archived Log Ji ءlaسly‎ 


:ARCHIVER (ARCn) 

هو P۲0٥٥٤5‏ اختیاری و لیس اجباري وواظیفتهاتکمن في نقل بیانات ال Archived Jl Redo Log Files‏ 
.1.٥‏ باعتباره اختياري فله حالتيين "مثا يعمل أو مغلق. و لوضعه في وضيعة الل يجب ان يکون ال 
Database‏ في وضعية ال C831۷ ٤06G‏ #۸ وفي حال تم وضع ال مءوطها( تحت هذه الوضعية فإن 


1 يعمل.‎ RC 
اذاً هناك حالتيين لوضعية ال مووطه٤هD تحددان عمل أو ایقاف ال م٣۸۸ هما:‎ 


:Archivelog 


عند امتلاء الملف الأول من ملفات ال Redo Log Files‏ ڍpî‏ البداً قي كتابة البيانات في الملف الثاني وتسمی 
هذه العملية Log Switch‏ ثم یقوم ال ۸R ٣€‏ بشکل أوتوماتيكي نقل بيانات الملف الأول الى ال 
.Archived Log Files‏ 


DATABASE TT 
DataFie 1 | File 1 : 
eet | erm . Archived 
File 1 ۳ 
Data file2 | File 2 Redo Log Log Files 
TT TTT 
Data File 3 File 3 


رسم 1.11 


: NoArchivelo 


عند امتلاء جمیع ملفات ال یذ۴ و10 0ء8 يتم اعادة كتابة البيانات "١٤س‏ ام0۷" في الملف الأول 
على البيانات السابقة > ولكن لا يتم كتابة البيانات فوق البيانات السابقة قبل ان يحدث Checkpoint‏ للملف 
أو مجموعة الملفات الممتلئة. 


سوف يتم التطرق لاحقاً لكيفية وضع ال عمsوط‏ واو( تحت حال .Noarchivelog Ja si Archivelog JI‏ 
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مالیا 
تنصيب و إدارة الأوراكل 


INSTALLING & MANAGING 
ORACLE 


DATABASE ADMINISTRATION TOOLS 


: يتوفر عدد من الأدوات "ء01٠1" في الاوراكل أهمها‎ 
ORACLE UNIVERSAL INSTALLER (OUT) ° 
ORACLE DATABASE CONFIGURATION ASSISTANT ° 
SQL PLUS 
ORACLE ENTERPRISE MANAGER (OEM) ° 


PASSWORD FILE UTILITY ° 


:ORACLE UNIVERSAL INSTALLER (OUI) 


یمکن استخدام ال 0٥1‏ لتنصیب "۹1٤و"‏ الاوراكل. في نظام الويندوز "۷1,٠"‏ تستطيع بدأ ال 
1 بالضغط على ملف التنصیب ال × م ام؟ › أما في نظام ال ×زو ل فیجب کتابة إe[[ھ)؟مآمںا.‏ 


الرسم 2.1 يوضح ال 01 في نظام الويندوزه"؟س نلم ۷". 


oracle Unîyersal Installer: File Locations 


File Locations 


Source... 


Enter the full path ofthe file representing the products} you want ID install: 


ڪڪ 
Path: [Eistagelproducts jar . 3 Browse... |‏ 


Destination... 


| GraHomeda 


lı |Ciorarcleiorad a 


About Oracle Universal Installer... 


Installed Products... 


الرسم 2.1 


27 


من أهم ممیزات ال 001: 

٠‏ يمكن تنصيب الأوراكل اكثر من مرة على ذات موقع التخزین مثل الو¡ 4۲4 باستخدام اسم 
مخلتف ٺل RACE HOME‏ الموضح في رسم 2.1 (أسفل کلمة ٥٤ھ"‏ ذtوءەD)‏ و یمکن 
تنصيب نسخة قديمة "اوم۷ 014" للاوراكل مع نسخة جديدة ""i0وم‏ ۷ سم" في ذات 
الموقع. 

٠‏ يمكن تنصيب الأوراكل من الإنترنت عبر وصلة ال H۲7۶‏ حيث تواجد نسخة الأوراكل» وبذلك يمكن 
تنصيب الأوراكل من قبل فرع شركة في دولة غير الدولة التي يوجد بها مقرها الأصلي (حيث تتواجد 
نسخة الأوراكل). 

ه يمكن أن يستعمل لإزالة الأوراكل من الجهاز أو السيرفر (Uninstall or D¢eins†a1[(‏ 

o‏ يعمل بعدد مختلف من اللغات مثل الانجليزي و الفرنسي و الألماني و غيرها. 

ه يمكن ان يعمل تحت الأنظمة التي لا توفر نظام ال G1‏ والتي تكون فيها الأوامر بشكل كتابي 
andصmmص€‏ ولیس كما في ال وس ٥م۷1‏ الذي يعمل تحت نظام ال 611 مثل الرسم 2.1. 


وتسمى الطريقة باسم الطريقة الصامتة M0٠"‏ ٤۸ء[1؟"‏ ويتم استعمال ملف يسمى مكرResp0‏ 
.File‏ 


:Response File 


هو ملف (any name.txt)‏ يحفظ البيانات اللأؤمة لعملية التنصيب مثل البيانات المطلوبة في الرسم 2.1 
( مثل بیانات ال Source‏ و .(Destination Û‏ 


:ORACLE DATABASE CONFIGURATION ASSISTANT 
:)2.2 يستخدم للأغراض التالية (انظر الرسم‎ 

ه تكوين البيانات "مء4ط0a)a'.‏ 

ه حذف البيانات "مءaوطDa)a".‏ 

٠ه‏ تعديل خواص البيانات "مءوطه)و5"'. 


.Templates J| ار‎ e 


سوف يتم التطرق لاحقا في فصل أخر لجميع الأغراض. 
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Ê :Orarle Database Configuration Assistant, Step 1 of 3 : Operations َ E 


Select the operation You want to perform 
® Create a database 
` Configure database options in a database 
"` Delete a database 


"` Manage Templates 


__ Caneel ي م ا‎ Back 
2.2 رسم‎ 


:SQL PLUS 

هي اداة تمكن المستخدم من التفاعل مع البيانات» حيث تمكنالمستخدام من الدخول الى البيانات» استخراج 
بيانات» اضافة بيانات» تعديل بيانات» واغلاق البيانات "مء4طو٤4(".‏ من المفروض أن تكون قد عملت مع 
ال SQ P8‏ خلال دراستك لل 5Q1‏ وتعرفت علیھ جیدا. 


Fila Edit Search ptians Help 


SQL#PIus5: Release 9.4.1.4.1 - Production on Fri Dec 13 BB:QAB:H1 28A? 
{te} Copyright 2881 Oracle Corporation. All rights reserved . 

Enter passuord: x¥#exx 

Connected to: 

Oracle 9i Enterprise Edition Release 9.9.1.1.1 - Production 

With the Partitioning option 


JServer Release 9.0.1.1.1 - Production 


SAL? | 


رسم 2.3 
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:ORACLE ENTERPRISE MANAGER (OEM) 


هو نظام دار ي يعمل على التحكم بمكوا نات الأوراكل وادارة البيانات من خلال نظام ال 601(اي يتم القيام 
بمعظم الأوامر من خلال استعمال الفارة .)"١ use"‏ 


من اهم مکونات ال ٤M‏ 0: 


CONSOLE ° 


ORACLE MANAGEMENT SERVER ° 
MANAGED NODES ° 


ORACLE 
SERYER 


REPOSITORY 
AEN | 
E e 
SERYER 


:Console 
1ا6" من الأدوات الهامة حيث تعمل كمحطة لإدارة جميع المهمات في آوراكل. من هنا يمكن‎ ٠٠۵١١" أداة‎ 


التحكم بالمءمو٤ءم1‏ ويمكن التحكم بال و»1اط ه1 و غيرها و تنفيذ المهمات عن طريق الفأَرة "موuم١"‏ 
والإختيارات المتعددة عوضا عن تنفيذ المهمات بواسطة جمل ال ا8Q.‏ 
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¥, Oracle Enterpriie anager Console Standalone 


Eile Havgaior hacet Tools Gonfiguraton Help REO 


EAE Hetwork 


El HGatahases 


Use Instance Management to 


¢ Start up and shut doen a database 
¢ View anid edil thE vali ûf iîNEARCE 
parameters 
* Manãğê ušÊrs' 5ê55ONS, aml vîêwı 
ciirrenily inning SAL and RE explain 
plan 
¢ Marağê If-dûöubî trafîëalliûnš 
* Monitor lorg-nunnimg operations 
¢» Cûrikrûl prûğêšSinqğ rFêšûurêêš viã 
Resource Plans 
* Marage stored confımrations 
¢ Airminister IOCES and SESS 
cansuming ive highest amounts of 
resmurces lif the Diagnûstics Pack is 
installed). To leami more about Instance 
Elick the Qulek Tour b 


ف ےچ 7 ت ك 


DESE 


رسم 2.5 


من الملاحظ من الرسم 2.4 أن ال 01ء٥‏ )شتطيع الدخول الى $٥۷٥۲‏ 1ء0۲4 بطريقتيين هما: 
oneاStanda:‏ بطريقة مباشرة دون الحاجة إئئ)4¢ءe Management Serv‏ eاOrac.‏ (سھم رقم 2) 
عبر ال :0M18‏ عبر .Oracle Management Server ÛJI‏ (أسھم رقم 1) 


DBA Tools 
:€٤هرو0إ[ءe هي مجموعة من البرامج التي يمكن تشغيلها من ال‎ 


."0و٤aطوءء" يستخدم لتشغيل واغلاق ومراقبة البيانات‎ :اnstance‎ Manager 
.Privileges s Users Accounts دژر‎ piy :Security Manager 

Manager‏ rageاSto:‏ يستخدم للتحكم في ال وموم 1ط ۲4 وال ۴16s‏ و٤04‏ وغیرها. 
Manager‏ maصe‌Sch:‏ یستخدم لتکوین وادارة ال ۲416s‏ و ۷1ew‏ وال s¢×eل"1.‏ 
:SQ1 PLUS Worksheet‏ اداة لكتابة جمل ال 5Q1‏ وتنفیذها. 


:Oracle Management Server (OMS) 


أھم مکونات ال Enterprise Manager‏ eاOrac‏ یقوم بدور الوسیط بین ال ۳C0 ns01¢‏ و Managed Û‏ 
Ns‏ في تبادل البيانات بالاضافة الى ادارة وأرuهءء۸‏ إءءل وعمليات مختلفة مثّل و)ررمE۷‏ ,sط0ل.‏ 
یقوم باستعمال ال راه)زوممه 8R‏ لتخزين بيانات النظام ٥)4"‏ ء)ءر؟" وبيانات البرامج والأدوات و 
بیانات .Managed Nodes Û‏ 
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:Managed Nodes 
ما یعرف‎ ×0٥ من ال مط( وخدمات أخری. یوجد علی کل‎ N0 قد تتکون ال‎ 
يقوم بالتواصل مع 0[18 ويؤدي المهام المرسلة من قبل ال‎ 0racاe‎ 1ntelاligent‎ Agen باسم‎ 


۴ي )›» وهو يعمل بشکل منفرد ویمکن ان يؤدي مهام مثل اغلاق و تشغیل ال مء ط ه٤‏ ویلزم 
Oracle ntelligent Agent‏ واحد فقط علی کل 4e‏ 0×. 


:PASSWORD FILE UTILITY 

تعرف باسم لس مه0 وتستخدم في تکوین ال .P4%W 0۲ ۴1e‏ 

لتکوین ال ٥ذ۴‏ لم سووه۴ يجب اتباع القاعدة التالية: 

Ş$ŞORAPWD FILE = filename PASSWORD = yourpassword ENTRIES=number; 
هي كلمة السر الخاصة ب‎ ٣ھیءw‎ od حیث ان ال ۴1۲ هو اسم الملف وموقعه على الجھاز› وال‎ 
تمل العدد الأقصى من المستخدميين الذين يحق لهم الدخول‎ Entries وال‎ .SYSOPER و‎ SYSDBA 
.SYSOPER,|SXSD 84A الى ال موو طData في أ‎ 


عندما تقوم بالدخول كمستخدم ال 84 23¥S5فانك‏ تدخل الى و ءطءS S۷8‏ ولیس ال 4٤1ء5‏ الخاص 
بك وكذلك عند الدخول کمستخدم ال ۲ER‏ 9¥50 فانك تدخل .PUBLIC Schema JÛ‏ 


تذکر: ملف ال ۴1٥‏ 0۲۵ سه۴ من الفصل الأول. 
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AUTHENTICATION METHODS 


للقيام بالمهمات الإدارية للبيانات "ءء4طو4(" يقوم الأوراكل بتكوين اثنين وامسںهءء۸ ۲ءء عند بداية 
تكوين البيانات "eء4ط‏ 044" هما S۷8‏ و ال 9۷S۲ EM‏ الذین یملکان جمیع ال eعم‏ ۴۷11 في 
الاوراکل أو ما یسمی ال .D8۸ 01e‏ 


ملاحظة: كلمة السر لل S۷5‏ عند بداية تكوين البيانات هي ااو٤ورذ_«ر0_ءع«هطء‏ اما كلمة السر لل 
.manager aê SYSTEM‏ 


.Database Data Dictionary Û "Owner" dllمnll هو‎ S¥S ملاحظة2: يعتبر ال‎ 


هناك طريقتتين يمكن السماح فيها للمستخدمين الذين يملكون ال ء۸1 8۸( الدخول الى ال #ووطو٤4(‏ 
وادارة ائبيlنlٽ‏ ھla: .Operating System Authentications Password File Authentication‏ 


:PASSWORD FILE AUTHENTICATION 


لقد تطرفنا قبل قلیل لل )ا1٤‏ ا ۴1١‏ 6۲۵سءه۴ والتي تستخدم في هذا النظام› ولتشغیل هذا النظام یجب 
اتباع الخطوات التالية: 


1- تکوین ملف ال Password ۴11e‏ عن طریق:ال .٥⁄0۸۸ ° W[D‏ 


2- وضع BMOPÊ_LOGIN_PASSWORDFILE JI‏ "۸ الذي هو أحد مکونات ال 
.EXCLUSIVE éذaÛ| gûl Initialization Parameter File‏ 


3- اعطاء "٤ہ "Gra‏ ال egesاPrivi‏ الخاص ب ¥50584۸ أو 9۷90۲8۸ الى المستخدمين 
الجدد الذين تم اختارهم للحصول ال R01۲‏ 08۸. 
مثال تطبيقي 2.1: 
الخطوة 1: اكتب التالي في ال 85ا۴1 اSQ؟‏ 
Ş$ORAPWD FILE=c:\loracle home\ora92\dbs\myfile PASSWORD=newadmin‏ 


ENTRIES=5; 


:2 الخطوة‎ 
SHOW PARAMETER REMOTE _ LOGIN _ PASSWORDFILE; 


اذا كانت الحالة غير E٣10 S1۷٤‏ فيجب تغيير الحالة في .Initialization Parameter File JI‏ 


:3 الخطوة‎ 
GRANT SYSDBA TO Ahmad; 


للدخول الى ال مووط هه اكتب التالي: 
CONNECT sys/newadmin AS SYSDBA;‏ 
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:OPERATING SYSTEM AUTHENTICATION 


بمجرد الدخول الى ال إعاءر؟ ع«ناوإءم0 (مثال: الويندوز) تستطيع الدخول الى ال #ءووطه)0a‏ دون 
الحاجة الى كلمة سر أو اسم مستخدم. 


ملاحظة: يجب أن يكو REMOTE_LOGIN_PASSWORDFI1LE ÛJI‏ في حالة NONE‏ ليعمل 
النظام, 

مثال تطبيقي 2.2: 

بعد الدخول الى ال 801۲18 اكتب التالي: 


CONNECT / AS SYSDBA; 


حlلںٽ :Remote Login Passwordfile JI‏ 
يوجد ثلاثة حالات يمكن وضع ال 1e¡؟0۲ Remote ogi ٣_۴44‏ فيها هي: 
EXCL [۷E ٠‏ : تحدد ان ce‏ آرو)5ہ] واحد فقط یمکن ان یستخدم ال ۴1٥‏ 0۲۵ wءھ۴‏ ویمکن 
|eطlء SYSDBAYPrivileges JI "Grant"‏ و YSOPER Privileges JI‏ لمستخدمین 
أخرين» وهي ضرورية لنظام اÛ .Password File Authehtiéa tion‏ 
:SHARED *‏ تحدد ان باستطاعۂ آکثر من ce‏ ہھ٤وو]‏ استخدام ال ٥۲۵ ۴e‏ wءھ۴‏ ولکن لا یمکن 


اضافة مستخدمين أخريين لل 9۷57084 أو ٤R‏ $50۲ والمستخدم الوحيد المعرف في الملف 
هو .S¥S‏ 


.Operating System Authentication مl¡زil‎ aرaرض¦‎ :NONE ° 
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OPTIMAL FLEXIBLE ARCHITECTURE 


یعتبر ال 0O۴۸‏ نظام لترتیب و توزیع ملفات ال مووطواهD‏ المختلفة على حسب نوعها أو استخدامهاء وهو 
معتمد في جميع الآنظمة التي يعمل بها الأوراكل مثل .Windows, U N1×‏ 
باستخدام نظام ال 0۴۸ يمكن ان نحقق عدة فوائد منها سهولة التمييز بين الملفات المختلفة وسهولة ايجادها 
وسهولة ادارة الأوراكل بتوزيع الملفات كل حسب نوعه»ء وتسهيل التحكم في التوسع الذي يطرأ على ال 
e‏ )هط في المستقبل. 
و باستخدام نظام ال 0۴۸ نستطیع: 

٠‏ اعتماد اسلوب ثابت لتسمية الملفات لکي نستطيع ايجاد الملفات بسهولة. 

.Oracle Database ùe Oracle Software J| تافأlم تفريق‎ 

ه تفريق ملفات النسخ المختلفة "د 0و۷" من الأوراكل. 


.Redo Log Files JI عن ملت‎ Control Files J| تفریق ملفات ال sع1ن؟ )04 عن ملفات‎ 


& ora32 


| FE E ew Favorkes Toc Heb | 


۳ 
L 
PD 8® 
0 


Madified: if BOOS b37 Ph 
Aktributêğ: (Rormêl) 


DBD De :0 


= 
3 


1 
DOD OCP OC ID :0 


OD e B@BP O °0 
1 


1-1 
8 
: 


jie :e O O +O iP 
B 


1 objecis) selected 


رسم 2.6 


كما تلاحظ توزيع ملفات ال مsوطههD‏ المختلفة الى مجلدات مختلفة. فمثلاً تجد ملف ال P۴assw 0۲ ۴1٥‏ 
تحت مجلد ال وط1 بالمقابل تجد ملفات ال ما۴ 1٥إ٤ره٥‏ تحت مجلد و٤4ل‏ ۲4ہ وھکذا... 
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INITIALIZATION PARAMETER FILE 


لتشغیل ال ٥٥ہ‏ ھ٤یہ!‏ یجب توفر ال .[nitia ization Parameter File‏ یمکن استعمال أکثر من ملف 
لنفس ال مءوطه)04. هنالك نوعان مj Initialization Parameter File Û‏ ھما: 


initS[D.0r4 يطلق عليه اسم الملف الثابت "ء۴1 ic)۾)S" ويعرف باسم‎ :P۴]LE 
spfileS[D.ora مصlڊ ويعرف‎ "Persist" † ۴11e" يطلق عليه اسم الملف المقاوم‎ :SPF|LE 
ہ ھ٤یہ[. فاذا کان اسم ال ceہوt٤یہ] "8ط" فیکون اسم‎ ce عبار عن رمز لإسم ال‎ S1 ملاحظة: ال‎ 
.(initDb8B.ora) املف‎ 
:Initialization Parameter File J| بعض محتوياٽ‎ 
.SGA_MAX_SIZE Û! مثل‎ SGA Ûy Instance Jlب الخاصة‎ "۴a4 ۸e)" العوامل‎ 
.!ہیtھ‎ ce اسم ال مووطه)ه« التي يعمل عليه ال‎ 
.€Cم٤٣٥1‎ ۴ [e4 اسماء و مواقع ال‎ 


‘Undo Segment J| بیانات عن‎ 
.Noatchilég siArchivelog la! دıدحت‎ 


INSTANCE 


:PEILE 


Initialization 
Parameter File 


uUSer 


رسم 2.7 


هو ملف من نوعية ال 1× الذي يمكن فتحه وتغييره بواسطة ال كدم٠٤ه٠.N‏ وغيرها من برامج الكتابة. 
يتم قراءة محتوياته عند بداية تشغيل ال مء ه)ء"1 ومعظم العوامل "١إ٥)ء_‏ و۴" الموجودة داخله لا 
تعمل بشكل دايناميكي ( يستلزم اغلاق وفتح ال مءء, )وم1 من جديد لكي يحدث التغيير) عدا بعض العوامل 
"rameteه"‏ التي يمكن تعدل دايناميكياً في الذاكرة ولكن تظل في ال ۲۴1۴ كما هي (أي انه عند 
تشغيل ال مء ء11 مرة أخرى يرجع الوضع الى قبل التعديل الدايناميكي). 

يوفر ال 001 ملف مبدني عند بداية تكوين ال مو ط هه اسمه 0۲4.٤1ہ:‏ يمكن استعماله لتکوین ال 
.PFILE‏ 
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بعض مکونات ال :P F۴1٤‏ 


db_block_size=4096 

db_cache_size=33554432 

open_cursors=300 

background _ dump_dest=C:\oracle2\ora92\admin\dbname\bdump 
core_dump_dest=C:\oracle2\ora92\admin\dbname\cdump 
timed statistics=TRUE 
user_dump_dest=C:\oracle2\ora92\admin\dbname\udump 
db_domain=oracle 

remote_login passwordfile=EXCLUSIVE 

control files=("C:\oracle2\ora92\oradata\ldbname\(CONTROLO(01.CTL", 
"C:\oracle2\ora92\oradata\dbname\(CONTROLO02.CTL", 
"C:\oracle2\ora92\oradata\ldbname\CONTROLO03.CTL") 
compatible=9.0.0 

db_name=dbname 

instance_name=dbname 

java_pool_size=33554432 

large_pool size=1048576 

shared_ pool size=33554432 

processes=150 

fast_start_mttr target=300 

sort_area_size=524288 

undo_management=A UTO 

undo_tablespace=UNDOTBS 


اعد :PFILE J|‏ 
ه كل العوامل '"ءإم)م_وإه۴" اختياريةء أي اذا لم يحدد ال 84( قيمة العوامل ""ءإم)مص "Paa‏ 
أو لم يتم كتابة العامل "۲۸۲4٥۲"‏ في ملف ال P۴۲1۴‏ يقوم الأوراكل بتحديد العامل 
"rameter"‏ و تكون قيمته هي القيمة المحددة سلفاً من قبل الأوراكل "ںاج۷ )[uوf¢("‏ 
ترتیب العوامل ")ص۲4 ه۴" في ال P۴1۴٤‏ غیر مهم. 


٠‏ اذا كان هناك أكثر من قيمة للعامل "١۲ع)ع‏ 4٣و۶"‏ الواحد فب فيجب وضع القيم داخل قوسين و 
تفریقهم بفاصلة كما في و٥۴‏ _1٥إ٤۸٥C.‏ 


هه تحدد قيمة العامJ "Paramter'"‏ بهذه الصيغة (العامل ك القيمة). 


ه يمكن استعمال (#) في الملف لوضع ملاحظات داخل الملف (هذه البيانات لل 84( ولا يقرأها 
الأوراكل). 
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:SPEILE 

هو ملف من نوعية ال رهط الذي يقوم بادارته ال ve‏ مS‏ مه0( فتحه و تعدیله) ویمکن تعدیل جمیع 
قيم العوامل "١٣٤ء4٣۴1"‏ الموجودة داخله بشكل دايناميكي (اي باستخدIم (ALTER SYSTEM JI‏ 
بحیث یتم تعدیل بیانات ال 59۲۴11۴ في الذاكرة أو الملف أو الأثنين معا (أي انه عند تشغیل ال ce‏ ۾)ی"1 
مرة أخرى تكون التغيرات التي اجریت على ال S۲۴1 ۴٤‏ بواسطة ال ER S¥S1 ٤M‏ ]ا۸ موجودة 
وثابتة). 

لا یقوم الاوراکل بتکوین ملف 5۲۶۴11٤‏ ابتدائي کما یحدث مع ال P۴1۴٤‏ ولکن یتم تکوین ال $۲۴1۴ 
من ال P۴1٤‏ کا سیأتي شرحه بعد قلیل. 

لتعدیل العوامل ٣4 ٥)٥۶‏ ے۴" داخل SP۴1٤‏ يجب اتباع القاعدة التالية: 

ALTER SYSTEM SET PARAMETER = VALUE [SCOPE = SCOPE_VALUE]; 
ملاحظة: استخدام ال [ ] في القواعد يدل على أن هذا الجزء اختياري و في حالة لم يتم كتابته يختار الأوراكل‎ 
يكون أحد الحلات الأكثر شيوعاً وهي تم اختيارها مسبقاً من قبل مبرمجي‎ (٥ه‎ [٤ ال ٤اه( . وال‎ 
الأوراكل.‎ 

أما حالات ال S)0PE_VA LUE‏ ثلاث رهي: 


:MEMORY °‏ يتم تغيير قيعة'غاآه۷" ال إءtءد‏ .هه فقط في الذاكرة» أي عند تشغيل ال 
مnst)ancا‏ مرة اخری تلغی التغیرات: 


:SPF]LE‏ یتم تغییر قیمة e"‏ ں[ھ ۷ ' ۴۲4m)‏ في ملف ال SP۴1€٤‏ فقط 


B0 1H‏ : یتم تغییر قیمة "ں۷1" للعامل 6٤6۲"‏ ھ۴" في ملف ال S۶۴1٤‏ والذاکرة 
معاً. 


ملاحظة: اذا لم يتم كتابة الجزء C0 PE-=SCOPE_VA LUE‏ فیعتبر الأوراکل انها 
.(Default Û ga BOTH) SCOPE=BOTH‏ 


:2.3 مثال تطبيقي‎ 
ALTER SYSTEM SET SHARED POOL ۉSIZE‎ = 33554432 SCOPE=SPFILE; 


بعض مکونات ال P۴11٤‏ 8: 


*. background dump_dest='C:\oracle2\ora92\admin\dbname\bdump' 
*. compatible='9.0.0' *.db_block_size=4096 *.db_cache_ size=33554432 
*. db_domain='oracle' 
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لیست کل العوامل "۴۲4٥٤٥۲۹"‏ في ال S۶۴1٤‏ اختیاریةء یوجد سبع عوامل "۴۸۲4۸٥٤٥۲۹‏ یجب 
ان تحدد هي: 


.BACKGROUND_DUMP_DEST 
USER_DUMP_DEST 
DB_NAME 

SHARED _POOL_ SIZE 
COMPATIBLE 
DB_BLOCK_BUFFERS 
CONTROL_FILES 


سوف يتم التطرق لاحقاً للعوامل '"ءرع)ع1ر ۶۸,۸" الجديدة لاحقا, 


Create SPFILE 


یمکن تکوین ال S۶۴1۴‏ من ال P۴1۴‏ اذا کان المستخدم يمlك S¥YSDBA ROLE‏ أو 
YS0PER Role‏ باتباع القاعدة التالية: 


CREATE SPFILE [='location and name'] FROM PEILE[='location and name']; 
في القاعدة اذ يمكن للأوراكل تكوين الأسم على النمط‎ $۴1٤ يمکن اهمال ذکر اسم و موقع ملف ال‎ 
المذكور سابقاً (و510.0ء۴11مء) وفي الموقع ال_٤[ں ه٥( وهو ضمن المجلد ءط1. كذلك الحال بالنسبة لل‎ 
حيث يختار الأوراكل الملف المعرف بالأسم و م.1810¡ وضمن المجلد وال.‎ P۴1٤ 


ملاحظة: قد يختلف الموقع ال ٤1ء5‏ من نسخة أوراكل الىأخرئا. بعض نسخ الأوراكل تكون الملف ضمن 
المجلد مووطواdat.‏ 


مثال تطبيقي 2.4: 


SQL PLUS JI من‎ 
CONNECT / AS SYSDBA; 


CREATE SPFILE FROM PFILE; 
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یمکن تعدیل ال SPF] ۴٤‏ من ال ٤ا )0NS0‏ باتخاذ الخطوات التالية: 


«Enterprise Manager Console JÛ ادخل‎ 

اختر الوضع «e‏ 10ول" .St4‏ 

اضغط على قائمة ال مءوطواو0 ثم قائمة "اسم ال #sوDatab"‏ 
يطلب منك الاسم و كلة السر. 

اكتب اسم ال 9۷59S 1 EM‏ وكلمة السر الخاص به. 

تأكد من وضع وه ٤م«ده)‏ الى الحالة 8۸4 S5؟¥S.‏ 

اضغط على قائمة ال eمو)یہ].‏ 

.Configuration jذlع اضغخط‎ 

„All Initialization Para eter ىذغE ضط‎ 


a mr Frei gi E FH an arg i r e EF man IR rı 


اکچ 


allrı Hr 2 2 
ETE E2" i 


fF Hete tk 
a [IE EEF EEE 
Ey UE E “HIE E aL 
HH Inzane e LET 
or” urahor 
اد د چا‎ 
E Larks 
lÎ lir SUE: 113 1832 E 1 Lage, EES 
lÎ Fas aura Or SUPER 


i513 ire SbalE 


¥ LiF ah 


ا ا 


FES F BÊ 1 e r luce lb irralin °1 
2 sare: EE 
#4 Faz Ur: 3 F al Serle 1 aE 
ر‎ Û | DBM: DEHAE 


ria :‏ 2= ر 
ج ڇڪ Dwele:‏ | || ااا 
ج کڪ : la aU‏ 


HEE 1ع‎ Ir ztar 2 Haris: LÛ JIS TIE 
E FeF “aor lb iıı !F ırlT rm IG PIPTPNI Ar 


Restle 1 Hoc 3: KE -‏ ا 


hil na hl! HAST HF‏ ا 


E DIKE JALE Read cir, klcde: li 


E EIR 


5 


SLE SEIERIEIE 


EAE 
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START UP A DATABASE 


يوجد ثلاث حالات يمكن أن نبدأ تشغيل ال ءءوط هه ولكل منها خاصيته والوظائف التي يمكن اجرائها في 
تلك الحالة« الحالات الثالثة بالترتيب : .NOMOUNT , MOUNT , 0PEN‏ 
:NOMOUNT‏ 


تسمى عملية ممواومآ مط ع«ذإواS‏ لأنه في هذه المرحلة فقط يبدأ تشغيل ال مء ه٤ء"[1‏ دون باقي أجزاء 
.Oracle Database Û‏ 


يمكن القيام بوظيفتين في هذه الحالة هماء 


„(CREATE DATABASE) SQL JI ةlaج عبر‎ Data ط‎ ase تكوين ال‎ 
.Control Files Û ه تكوين أواعادة تکوین ملفات‎ 


سوف يتم التطرق لاحقاً لكيفية تكوين ال عءوطواو( باسخدام جمل ال 1ا@5. 
يتم في هذه المرحلة عدة أمور هي: 
٠‏ تتم قراءة ملف ال Parmeter ۴1e‏ iationاnitia]‏ بحیث يبحث الأوراکل على ملف 
SPF1LE‏ إن لم یجد یبحث عن ۴۳۳1۲۴٤‏ وإن لم يجد تتم قراءة الملف وإم.٤نما.‏ 
ه حجز مساحة من الذاكرة لل .S64‏ 
.Background Processes Û Î e‏ 
فتح ملف یسمی وہ[.۲۲515ء1[ه وملفات تسمی "۲۲۸۰۲.۴16 . 
سوف يتم التطرق لاحقا ٺل Trace Files s 4le1151D. [og‏ . 


.NOMOUNT Jl Jمعي‎ „ala B_NAME "Parameter" Jماعلا ملاحظة: يجب تحديد قيمة‎ 


:MOUNT 

في هذه المرحلة يمكن القيام بوظائف مهمة مثل: 
îخيıر .Data Files JI slaw "Rename"‏ 
٠‏ امكانية وضع ال مووط0a)a‏ تحت وضعي .NOARCHIVELOG yi ARCHIVELO0G JI‏ 
eعملJ‏ صilة .Database J "Recovery"‏ 

يتم في هذه المرحلة عدة أمور هي: 


ه فتح وقراءة ملفات .Control Files Û|‏ 
٠‏ ربط ال مsوطه)ه‏ بال مء« واوم!ا الذي سوف يعمل عليها. 
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:OPEN 


هي الحالة العادية التي تم العمل فيها بواسطة ال 50۲1S‏ ويتم اجراء تعديل وحذف واضافة بيانات 
وغيرها من المهام. 


يتم في هذه المرحلة عدة أمور هي: 


. Online Data Files JI تج‎ e 
.Online Redo Log Files JI gid e 


في حالة فشل فتح ملفات ال و٥۴11‏ واد( وال ٥ذ۴‏ ٠لءR‏ او في حالة حذفها أو نقلها من مواقعها المحددة 
في ال C٤٥1 ۴1e‏ فلا یمکن ان تعمل الحالة .0P E۸‏ 


lal Initialization Parameter Files J مخزنة في‎ C٥٤01 ۴16s ملاحظة: اسماء ومواقع ال‎ 
.C0" ۲01 ۴ ¡[es فهي مخزنة في ال‎ Redo 10g F۴ ¡[es وال‎ (4٤4 ۴1e اسماء و مواقع ال‎ 


STARTUP Command 

لتشغيل ال مsوط4٤a‏ 5 في احدى الحلات-المذكورة سابقاً تستعمل القاعدة التالية: 
STARTUP [FORCE] [RESTRICT] [PFILE='location and name']‏ 
[OPEN [recover] [database’sname] | MOUNT | NOMOUNT |];‏ 


ملاحظة: استخدام ال | في القواعد يدل على انها (أو) "© . فمثلاً لا يمكن MOUNT J‏ و OPEN Û‏ 
ان يتبا معا. 
أوامر القاعدة : 


٤اP۴1:‏ سبق ذكر ان الأوراكل يبحث عن الملف عند بداية مرحلة ال N1‏ ا0 "0M‏ ولكن يمكن للمستخدم 
تحدید ملف محدد عوضاً على ان يقوم الأوراكل بالبحث عنه. 


:RECOVER‏ خاصة فقط بمرحلة ال 0۲8۸ اذ لا یمکن کتابتھا مع ال 0N‏ 10 وعند استخدامها 
يقوم الأوراكل بعمل عملية ال ٤R‏ 0۷] ۸ للبيانات. 


"ESR 11‏ : تحدد المستخدمين الذين يحق لهم الدخول الى ال #ووطهtه0‏ وهم من يملك ال 
Restricted Session Privilege‏ التي سوف یتم التطرق لھا لاحقاً. 


:۴0RCE‏ اذا كان ال #ع و11 يعمل في احد الحالات فيمكن اغلاقه ثم تشغيله مباشرة في الحالة العادية. 
اذا هي مثل عملية ال "١ءء‏ ®" في الويندوز. 
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مثال تطبيقي 25 
لاستخدام قاعدة ال 0۲ا1 931۸۸ يمكن القيام بالتالي: 
1- ادخل الى ال SQL PLUS‏ أو عبر ڑÛ .Command Prompt‏ 
2- ادخل اسم المستخدم و كلمة السر. 
3- يجب الدخول الى 84 S¥S5‏ عن زرıق CONNECT \ AS S¥SD84;‏ 
4- اغلق ال موو طو٤و‏ بواسطة الجملة lلتlلية: SHUTDOWN;‏ 
;۶آ S1 R‏ في هذہ الجملة یعتبر الأوراکل انھا 0۲٤۸‏ باعتبارھا ال )[uںهfء0.‏ 


STARTUP MOUNT; 
STARTUP NOMOUNT; 


:ALTER DATABASE Command 
: يمكن ان تستخدم في عدد من الوظائف منها‎ 
: تغيير حالة ال seواaوtوD من‎ -1 


.MOUNT J NOMOUNT ° 
OPEN yil MOUNT ° 


يمکن استخدام أمر ال L۲ ER DAA BASE‏ باتباع القاعدة التالية: 


ALTER DATABASE [database's name] MOUNT | OPEN; 


مثال تطبيقي 2.6: 
بینما يتم استخدام حالة ال NOM OU N1‏ يمكن التحويل الى ال 71ا0" بكتابة التالي: 


ALTER DATABASE MOUNT; 


2- لوضع ال موو طواه( في حالة القراءة فقط :"Read-Only Database"‏ 


يمكن فتح ال مء ط)4( في حالة 0۴٤۸‏ بدون السماح بتغيير البيانات في ال مء4طه)ه( باستخدام 
القاعدة آلتالية: 


ALTER DATABASE [database's name] OPEN READ WRITE | READ ONLY; 


.Default J| ga READ WRITE jİ lll ع‎ 
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مثال تطبيقي 27 
بينما ال موو ط هاه( في الحالة العادية "R2۸5 W۷ R1۲۴"‏ يمكن التحويل بكتابة الجملة التالية: 


ALTER DATABASE OPEN READ ONLY; 


من الوظائف التي يمكن القيام بها بينما ال مءوطهtة0‏ في وضعي :READ ONLY J!‏ 
۰ استخراج بیانات عبر جمل ال ا@8. 


.Online s Offline ùıڊ‎ Data Files J| تغيير وضعية‎ ٠ 
.Tablespaces Jly Offline Data Files JI JE Recovery J| ةıلمعب القيام‎ 


:Restricted Mode 


یمکن تشغیل ال می4 طa)4‏ 5 في هذه الحالة لإعطاء المجال للمستخدمين الذي یملکون 
Restricted Session Privilege‏ من القیام بمهات خاصه. 


مثال تطبيقي 2.8: 


لتشغيل ال موو ط)0 في حال Réstricted J|‏ : 
STARTUP RESTRICTED;‏ 
يمكن تحويل الحالة بشكل دايناميكي باستخدام: 


ALTER SYSTEMBNABLE RESTRICTED SESSION; 
ALTER SYSTEMDISABLE RESTRICTED SESSION; 


في بعض الأوقات (وخاصة بعد وضع ال Qع)ء1إ٤ء۸)‏ يريد ال 84 (أو من يملك الصلاحيات) باخراج 
بعض المستخدمين من ال ءء4طه)ه للقيام ببعض المهمات. يمكن القيام بهذه المهمة عبر: 


ALTER SYSTEM KILL SESSION 'SID, SERIAL#'; 


ال S1‏ هو رقم ال ووم الخاص (يعطى لكل «موومS‏ عند بداية تشغيله رقم خاص به) يمكن استخراجه 
مjù .V$SESSION‏ 


ال 1۸1# SER‏ ھو رقم خر ممیز "٥ں‏ 1ں" یعطی لکل «ه‌ووم؟ ویمکن استخراجه من ایضاً من ال 
.VŞ$SESSION‏ 
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مثال تطبيقي 2.9: 
يمكن القيام بعملية "ووم 11" باتخاذ الخطوات التالية: 


ه يجب أن يكون هنالك أكثر من مستخدم يعملون على ال مودطهه( في نفس الوقت» للقيام بذلك 
ادخل الی 7Sڄ 5Q۴‏ اول باسم مستخدم ثم افتح ال 5Q۲ ٥S‏ مرة أخری وادخل باسم 
مستخدم اخر. 

username = SCOTT , password =TIGER pدختwl و‎ SYSTEM oدختسا‎ 


ه يتم كتابة الجملة التالية من ال 7۲٤M‏ S؟¥S؟:‏ 


SELECT USERNAME, SID, SERIAL# 
FROM VŞSESSION 
WHERE USERNAME = 'SCOTT!'; 


ه يظهر الناتج التالي (يختلف من جهاز الى أخر) 


USERNAME SID SERIALF# 


SCOTT 9 51 


یکتب مستخدم ال 9۷۹۲٤ M‏ التالی: 
ALTER SYSTEM KILL SESSION '9, 51';‏ 


٠‏ يتم اغلاق ال «هووم؟ الخاص بالمستخدم .5S٣٥0 ٤١‏ يقوم ال ٥ M]0١‏ بمهامه مباشرة لمعالجة 
الأثار التي يمكن ان تنجم عن أغلاق ال «مذووم؟_الخاص بالمستخدم 11 S٤٥00‏ واذا قام S€C01T1‏ 
بطلب جملة 5Q1‏ تظهر الرسiلة‏ llتlلıة: YOUR SESSION HAS BEÈN KILLED‏ 


E 
File Edit Search Dptions Help system USEF 


2 FROM U$SESSION 
3 HWHERE USERNAME = 'S$COTT'; 


ا 


USERHAHE SID SERIALH 

SCOTT ي‎ 21 

SQL+* ALTER SYSTEM KILL SESSION '9,51'; 

ا ا 
ا× ادا 
File Edit Search Options Help SCO‏ 
SP2-BBH2: unknoun connand "SES" - rest of line ignored . |‏ 


SQL#* SELECT * FROM EMPLOYEES ; 
SELECT * FROM EMPLOYEES 


¥ 
ERROR at line 1: 
ORA-BBB28: your session has been killed 


SQL> 


| اا 
رسم 2.9 
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SHUTTING DOWN THE DATABASE 


يمكن اقفال ال مووطوغو0 في اربع حالات ھa: NORMAL, TRANSACTIONAL,‏ 
.IMMEDIATE, ABORT‏ 


ملاحظة: عادةٌ ما تكون عملية اغلاق ال مووط وه من أجل عملي ال up)ء84.‏ 
ملاحظة2: لإغلاق ال ase‏ ط 0ata‏ تحتاج | .SYSOPER yİ S¥SD8BA‏ 
لإغلاق ال مووطهاه( في احدى الحلات المذكورة تستعمل القاعدة التالية: 
SHUTDOWN [NORMAL] | [TRANSACTIONAL] | [[MMEDIATE] | [ABORT];‏ 


مع العلم أن 1 NORMA‏ هي ال Defa u1‏ أي عند کتابة ال W٩‏ 3110۲00 بدون أي من الحالات 
الأربع يفترض الأوراكل أنها الحالة ال )إuوfء50.‏ 


:NORMAL 
بهذه الحالة يتخ التالي:‎ Database J| في حالة اغلاق‎ 


۵ لا یسمح بدخول مستخدمیین جدد لل:مء4طة04. 

٠ه‏ لا يغلق ال ماهد قبل خروج جميع المبنتخدمين منه» أي ان الأوراكل ينتظر حتى يفرغ 
المستخدميين من مهامهم ثم خروجهم لكي يتم اعلاق_ال مءوطه)04. 

.Redo Eoğ. Files JI ll Redo Log Buffer J| ٽانlيب يتم نقل‎ 

.Data FilesdÛ! yil Database Buffer Cache J| تانlيب يتم نقل‎ 

في حال وجود عملیات لم یتم حدوث .ROLLBACK ll دحيê COMMIT‏ 

.Background Processes J| ناء وجو‎ 

ازالة مساحة ال S64‏ من الذاكرة. 

اغلاق ال 4e‏ طھ٤ھD‏ ثم اغلاق ال .1ns†4 nce‏ 


ملاحظة: لا يستلزم ان تتم عملية رم ۷٠ء٠8‏ للبيانات التي كانت موجودة في ال مء و٤و.!]‏ باعتبار انها 
نقلت الى الملفات الفيزيائية. وعملية ال رإء۷هءء8R‏ هي العملية المشابهه لوظائنف ال۸ ۴۷M0‏ و × SMO‏ . 


:TRANSACTIONAL 
عدا الإختلافات التالية:‎ NORMAL J| بهذه الحالة یتم جمیع خطوات‎ Database ÛJI في حالة اغلاق‎ 

٠‏ لا يغلق ال مووطهtه‏ قبل انهاء المهمات التي طلبها جميع المستخدمين منه» أي أن الأوراكل ينتظر 
حتى يفرغ المستخدميين من مهامهم التي طلبوها قبل حدوث أمر الاغلاق ولا ينتظر أن يخرج 
المستخدمين من ال مووطوه لتتم عملية الاغلاق كما يحدث في ال .NOR M41‏ 

ه لا يسمح بالقيام بمهمات جديدة من قبل المستخدمين بعد أمر الإغلاق. 

ه يتم اخراج المستخدم من ال مووطه)ه( عند انتهاء المهمات التي طلبت قبل عملية الاغلاق. 


ملاحظة: لا يستلزم ان تتم عملية رم 0۷ء٠8‏ عند تشغيل ال مء ه)وه] مرة أخرى. 
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:IMMEDIATE 
عدا الإختلافات التالية:‎ NORMAL Û بهذه الحالة یتم جمیع خطوات‎ Database ÛJI في حالة اغلاق‎ 


ه٠‏ يتم اغلاق ال مط هه( فوراً دون انتظار خروج المستخدمين أو انهاء مهامهم التي طلبوها قبل 
أمر الاغلاق. 

ه المهمات التي تم طلبها قبل أمر الاغلاق تلغى وأية تعديلات طرأت على البيانات بسببها تزال وتمسح 
(بشرط ان تكون المهمة ما تزال تعمل عند أمر الإغلاق( ويحدث .ROLLBACK ll‏ 


ملاحظة: لا يستلزم ان تتم عملية ء۷٠٥٠8‏ عند تشغيل ال #ء« هوم[ مرة أخرى. 


:ABORT 


في بعض الحلات الخاصة عند عدم استطاعة الأوراكل اغلاق ال مووطه٤هD‏ بأحد الحلات الثلاث السابقة يتم 
في حالة اغلاق ال موو طه٤ه‏ بهذه الحالة يتم التالي: 


٠ه‏ يتم اغلاق ال مءوط هه( فوراً دون انتظار خروج المستخدمين أو انهاء مهامهم التي طلبوها قبل 
أمر الاغلاق. 

ه المهمات التي تم طلبها قبل أم4الآغلاقتلغى و أية تعديلات طرأت على البيانات بسببها تزال وتمسح 

(بشرط ان تكون المهمة ما تزال تگال ”عند أمر الإغلاق( ولا يحدث .ROLLBACK lq‏ 

.Redo Log Files Û Jll Redo Log Buffer J| تانlıب لا يتم نقل‎ 

Data Files JI ll Database Buffer Cache J| تIنlب‎ Jقن لا يتم‎ 

المهمات التي لم يحدث لھا .ROLLBACK lq ùدكي ¥ COMMIT‏ 

یتم اغلاق ال مھ ط هھ وال "٥‏ هی[ بشکل فوراي. 


ملاحظة: يستلزم ان تتم عملية رإء ۷٠0٠ء8‏ عند تشغيل ال مء ه)كو] مرة أخرى. 


ملاحظة2: تأثیرات ال ۲R ۲ ۴ORO٣٤‏ و عند حدوث أي عَظل في ال مء ء1 يؤدي الى اغلاقه 
هي ذات التأثيرات .SHUTDOWN ABORT Ji‏ 
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DIAGNOSTIC FILES 


تعتبر ملفات ال ناومعٍه1( ملفات مهمة لإدارة ال مم و)وم] لأنها تخزن بيانات حول العمليات المختلفة 
التي تجرى على ال مووطه)54. يوجد عدد من ملفات ال نوم معه1( منها: 


[ER1 L0G FILE *‏ : يتم تخزين البيانات حول العمليات أو المهام اليومية التي تجرى على ال 
.Database‏ 


Background ÛJI J> يتم تخزين بیانات‎ : BACKGROUND TRACE FILES 
.Processes 


15SER "RACE FILE °‏ : يتم تخزين بيانات حول الأخطاء الفادحة التي يقوم بها المستخدمون 
والتي قد تؤدي الى تعطل ال مووطو٤و(‏ وبذلك تساعد على اكتشاف الاسباب التي أدت لتعطل ال 
.Database‏ 


:ALERT LOG FILE 


لکل ٥٥ہ‏ ھ٤یہ!‏ ملف ع0 ۸1٥۲٤۲‏ بحیٹ اذا ل يقم المستخدم بتکوینھ یقوم الأوراکل خلال بدا ال ceہ‏ )یہ1 
بتكوين الملف (خلال مرحلة ال )NNOMNOU NT‏ وهو يعرف باسم .a1lertS[D.10g‏ يعتبر Alert Log ÛJI‏ 
هو المرجع الأول في البحث عن الأخطاء (تشتخيص) التي حدثت في ال موو طهاه( بشكل يومي. 

موقع ال ۴11۲ ۸1٥۲۲‏ محدد من قبل العامJل‏ "îıéteFضPara" .BACKGROUND_DUMP_ DEST‏ 


تذکر: جاءٍ ذكر allامJ BA €CKGROUNDADUMP_ DEST "Parameter"‏ في موضوع ال 
.SPFILE‏ 


یتم تخزین البيانات عديدة في 0g ۴٥‏ ۸1۲۲ منھا: 


توقیت بدأ تشغيل ال مء و٤وہ1‏ وتوقيت الاغلاق. 

.Background Processes JI Jیغشت توقیت بدا‎ 

بیانات حول ال طSwi)c‏ 0gا.‏ 

بيانات حول الاخطاء التي زۈهرت ."Error Messages"‏ 

بیانات حول تکوین ال .٣۵ (1٥٤م4 ces‏ 

بیانات حول تکوین ال d0 Seg "٤"4‏ €ا. 

جمل ال 8Q‏ التي تحتوي على الأمر 1٤8‏ ا۸. 

رقم ال L0 Sequence‏ الخاص بال nine Redo 10g ۴1e‏ الذي يتم العمل عليه من قبل ال 
LGWR‏ 


. Undo Seg nes Jl سوف يتم التطرق ¥حقاً‎ 


تذکر: جاء ذکر ال Sequence Number‏ ع0ا في الفصل الأول. 
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:BACKGROUND TRACE FILES 

يتم تخزين بيانات حول الاخطاء التي تحدثها ال ومءء ع١٤٠۲۲‏ أ«”u٠إع)ءه8.‏ يتم تكوين الملفات فقط عندما 
تحدث الأخطاء (أي انه في حال عدم حدوث اخطاء لا تكون الملفات متواجده). 

موقع الملفات محدد من قبل العامل .BACKGROUND_DUMP_ DEST "Parameter"‏ 


:'USER TRACE FILE 
يتم تخزين بيانات حول الأخطاء الفادحة التي يقوم بها المستخدمون والتي قد تؤدي الى تعطل ال مووطوخة(‎ 
موقع الملف محدد من قبل العامل‎ ."14-٠" التي تم طلب مراقبتها‎ 5Q وبيانات حول ال‎ 
.USER_DUMP_ DEST "Parameter" 
و المحدد ب 10 میغا‎ 1۸× DUMP_FILE_S1IZE "P44٤٣" يتحكم في حجم الملف العامل‎ 
بايت. يمكن تشغيل أو ايقاف الملف في ال «هذووم؟ الواحد او في ال مم و٤ءم! (كل ال و«مذوومS التي‎ 
موجودة في ال مع« وا٤وم1) عبر كتابة التالي:‎ 
:Sمیو10‎ 1 في ال‎ 
ALTER SESSION SET SQL _ TRACE = TRUE; 
:1ہ؟t4‎ ۸e في ال‎ 
:Initialization Parameter File J| ألتالي في‎ "۴4١4 او عند وضع قيمة العامل "عمد‎ 
SQL _TRA@E = TRUE 
وتسجيل»بيانات(جوالها والأخطاء التي سببتها.‎ 5Q1 جميع جمل ال‎ "1۲4٥٥" وبذلك يتم تعقب‎ 
.SPFILE JI ي موضع‎ USER_DUMP_ DEST "Parameter" Jمlalا تذکر: جاء ذکر‎ 
تسمی بالقاعدة‎ 8acekع٥u”4‎ ۲٣٥۲ فمثلاً ملفات ال‎ .))٣٤( بالرمز‎ ۲٣۹٥١ ۴٥و تعرف ملفات ال‎ 
مثل‎ sid? RO٣CESSNA۸ ME .†c التالية: ( كما الملفات الموجودة في نسخة الأوراكل الخاصة بي)‎ 
هو اسم ال ۸# هtو!] في جهازي والذي يحدد عند عملية التنصيب).‎ dbname) dbnamePMON. tre 


وكذلك الحال بالنسبة أملفات User Trace J|‏ في تسمی بالقاعدة التالية في نسخة الأوراكل الخصة بي: 
.ORA00853.trc Jî ORAPID.tre‏ 


ملاحظة: قد تختلف قاعدة التسمية من نسخة آوراکل الی آخری ولکن ال و٥۴1 ۲۲۹٤٤٥‏ تنتهي دائماً ب ).٤٣٤(‏ 
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ORACLE MANAGED FILES (OMF) 


تسهل ال M۴‏ ادارة عدد من ملفات الأوراكل اذ يكفي تحديد مواقع الملفات فيقوم الأوراكل بالاهتمام 
بالملفات و تكوينها وحذفها وتسمیتها. یمکن تحدید مواقع الملفات باستخدام عاملین "۴۸٣4٥٤٥۲۹"‏ اثنین 
جدیدن من عوامل ملف ال Para mءامإ ۴11e‏ izationاntia]‏ اضيفا في النسخة التاسعة من الأوراكل 
"Oracle9i"‏ ھما: 


:DB_CREATE_FILE_DEST °‏ الذي یحدد مواقع ال Data ۴6s‏ . 
(B8_€REATE_ONLINE_LOG_DEST n °‏ : يحدد مواقع ملفات ال 8R ed0 10g‏ وال 
.C0ntro1 Files‏ یدل الحرف (۸) على رقم العامل "۲ع٥‏ ۶۲4" بیحث یکون من واحد الى 

ملاحظة: يمكن استخدام أحدهما أو كلاهما, ولا يشترط استخدام الاثنين معاً. 
ترتبط کل ce‏ ےم٥1ط‏ ۲ بملف من ملفات ال 0ata ۴1٥s‏ ( 1ےcذعہا[-ica1ذووط۴)‏ بحیث یکون لکل 
espaceاab"‏ ارتباط بملفات من ی٥۴11‏ و4(. اي انه عند حذف ال ٥ceےمءم‏ 1طا۲ یجب حذف ملف ال 
هاه( المرتبط معها وإلا قد يسبب مشاكل عند عملية ال مu‏ )ء4 8/ اذ انه لا فائدة من حفظ ال و٤و0]‏ 
۴s‏ باعتبار ال ce‏ 4م٥1‏ ط۲۹ تم حذفها. 
يجب على ال 084 البحث عن الملفةالمرتبطاوجذفه بطريقة عادية (كما يتم حذف أي ملف في الويندوز أو 
ال ×1 N‏ ال أو غیرھا). آما اذا تم استخدام طریقة ال M۴‏ یقوم الأوراکل بحذف ال یذ۴ (٤a‏ دون تدخل 
ال D84‏ أي بطريقة أوتوماتيكية وهذه أحد فۇائد استخدام ال .0M۴‏ 


يتم استخدام )٥۲4_(‏ في بداية اسماء ملفات ال M۴‏ 0ل دلالة عليها. 


مثال تطبيقي 2.10: 

DB_CREATE_FILE_ DEST = 'C:\oraclelora92\oradata\u01'" 
DB_CREAE ONLINE _LOG_DEST 1 ='C:\oraclelora92\oradata\u02' 
DB_CREAE ONLINE _LOG_DEST 2 ='C:\oraclelora92\oradata\u03' 
.ALTER SYSTEM ماIدختساب يمكن تغيير القيم "ءعں 1و۷" بشكل دايناميكي‎ 


ALTER SYSTEM SET 
DB_CREATE FILE _DEST='C:\oracle\lora92\oradata\u04'; 


بعد ان يتم تحديد العوامل ٥)٥١"‏ هد۴" (كما في المثال 2.10) تتم عملية تكوين ال عوط هه باستخدام 
مر ..)REA E DATABASE‏ اذا فشل تكوين ال وهاه( يقوم الأوراكل بحذف الملفات التي تكونت 
من خلال .OMF‏ 


يمكن الحصول على معلومات حول الملفات التي تكونت بطريقة gy DBA_DATAFILE ja OMF J‏ 
.VSLOGFILE‏ 
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الفمےل الثال 


تکوین الداتا بيس واسنةد ام 
الداتا ديكشينوري 


CREATING A DATABASE & 
USING THE DATA DICTIONARY 


PRE-CREATING STAGES 


عملية تكوين ال موو ط٤د(‏ تحتاج الى تخطيط وتحضير مسبق» يجب على ال 84( اعداد التالي: 
ه الحجم الكافي لكل من القرص الصلب ")ءز0 "14۲١4‏ و الذاكرة في السيرفر. 
٠‏ دراسة نوعية النظام "٠nءءر؟‏ ع«ذاوإءم0" الموجود في السيرفر. 
ه وضع خطة لتوزيع الملفات في موقع التخزين لحماية ملفات ال مووطو٤ة0.‏ 


٠‏ تحدید اlعوlمJ Initialization Parameters‏ وخاصة اÛ D(B_ BLOCK_ SIZE‏ الذي لا 
يمكن تغييره بعد عملية التنصيب. 


.S¥SD 84A و توفر ال‎ )Password File او‎ Operating System ) اختيار نظام الحماي‎ ٠ 


ه معرفة اذا كان يراد تكوين مودطو)ه( جديدة أو يراد نقل ال مووطه٤ه(‏ الموجودة من نسخة 
أوراكل أقدم الى نسخة أجد › عند ذلك يجب استخدام Data Migration Assista ıt Û|‏ 


ه تحديد الطريقة التي سوف يتم-بهابتكوين ال مودوطهاد الجديدة › إما عن طريق استخدام 
REA E DATABASE‏ € في ال.8 SQ‏ (تسمى الطريقة اليدوية) او عن طريق مووطو)54 
.Configuration Assistant‏ 
٠ه‏ وضع خطة عملية دورية لإجراء عملي ال upں)ء84.‏ 
نقاط مهمة: 
1- ينصح بتوزیع ملفات ال ۴1۲ ٥٥)٠1‏ على مواقع مختلفة أ آقااص صلبة مختلفة. 
2- ينصح بتوزيع الملفات المتشابة في مجموعات ال وه 0ء8 الى مواقع مختلفة أو أقراص مختلفة. 
3- وضع نظام لتسمية الملفات ليتسنى ايجادها بسهولة. 


4- تفريق عناصر ال مووطهه( التي لها مراحل حياة مختلفة(قصيرة أو طويلة) الى مواقع مختلفة لكي يقل 
ما يعرف ڊlصم .Disk Fragmentation‏ 


5- تفريق ال sم1‏ اه٣‏ وال وم×م لد[ الى كمءومءء1طهو1 مختلفة لتنظيم عملية ال ut‏ م† pu )/0 u‏ 1. 
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DATABASE CONFIGURATION ASSISTANT 


Create a Database, Configure Database Options, :يئتllب يمكن عبر ال(۸4 58°( اليم‎ 
.Delete a Database, and Manage Templates 


:CREATE A DATABASE 


للقيام بتكوين عوط ه)ه جديدة أو القالب "ء)دامn٠ء1".‏ والقالب عبارة عن اختيار ال مووطوD5at‏ 
ائم وحفظها لكي يتسنى استخدامها في موقع أخر. مثلاً يمكن ان يقوم الفرع الأساسي للشركة بتكوين 
قالب ال مووطه)ه( وتوزيعه على الفروع لتكوين ومووطهاه متشابه في جميع الفروع. 

يمکن تكوين نوعین من القوالب "'یع)هام_. ۲۶" هما: 


٠‏ بدون ال و۴1 و٤a(:‏ فقط اختيارت ال مءوطو٤ه(‏ دون الملفات (لمعرفة الاخيارات اضغط على 
Det"‏ سShow").‏ تکمن فائدته انه یمکن تغییر جمیع الأختیارات وال ٥114ھ‏ i)iہ1‏ 
Parameter‏ بعد تکوین القالب "e)ھ[pمص‏ 1¢ ". 


مع ال 1ذ۴ ه)54: يكون القالب/متكوناً من اختيارات ال مsوطه)ه0‏ مع وجود ملفات ال و)54 
.Files‏ یتم تکوین ال nto] ۴ ¡[es‏ و ال R ed0 [0g Groups‏ بشکل أوتوماتیکي» یمکن تغییر 
اسماء ومواقع ال (1٤a ۴1٥s‏ Kولکن‏ لا یمکن حذف ال ی٥۴1‏ و٤4(‏ وتکوینھا من جدید وکذلك 
ینطبق الحال على یce‏ ھم 1ط ھ۲ ٣یلا‏ یمکن تعدیل ال tion ۴a4 e)۶‏ izaاnitia]‏ بعد تکوین 
القالب "Template"‏ . 


يوجد عدد من القوالب المعدة مسبقاً Nan"‏ مام "56 تظهر بالرسم 3.1: 


E: Oracle Database Configuration Assistant, Step 2 of 3 : Database Templates 8 2 EA 


Select a template frorm the following listto create a database: 


| [eı Data Yare hOUSE 1 ES 
٠ Transaction Processing res 
# General Purpose Es 
2 New Database Nn 


Cancel Help ¢4 Back Nex! 3 


بعد أن یتم اختیار أحد القوالب "ء٤ھام‏ ص٤۲۶"‏ يطلب اختیار اسم اÛ Database‏ سم Instance J|‏ 
المعرف بالرمز .S1‏ 


O Oracle Dakabaşe Configuration Assistant, Step 3 ol ã : Database Tenliiealian اا‎ × 


Spi Ihe allowing dalatase irfoerralian 


An Oracladl database |5 unlqlrely Hendifiad by a lokal Database Namie, tpically of the form 
"namie dormraln". 


loa Database Narnıê: 


Adalabasê |z refererred bf al leas one Oradledl Instanıpe wfılchı îs nq ely ide riified Trot afty 
oer inzlarnce on thls comiplfer by arı Oracle System Identifier {SCN 


BID: nooo 


cangel ) Help j & Back | 


رسم 3.2 


في حال تم اختیار القالب "٥4طه٤Da‏ س" یتم اڅتیار الممیزات "۴٥۵)»۲٥۹"‏ التي ترید استخدامها في 
.Database Û‏ 


PW Oradle Database Configuration Assistant, Step 4A ol § : Database Options 1 اا‎ × 


Datahasa Features || Custom Seripfs 
Select the feafures you want ba conf gure for usa İn yur database: 
F# ûrarle špalial 
IF Oracle Ula Search 
F Qrale Lael Beturily 
F# Oracle OLAF Semices 
# Example Schemas 
F# Hirmarı RESSURtES 
HF rder Eniry 
FF Froduci Media 
HW Sales Hiory 


FH Shipping 


Hi dilional falabtase tonfiğuraliêfîrê... ا‎ 


Caneel Help Î 3 | Finish 


رسم 3.3 
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المرحلة التالية يتم اختيار البيئة التي سوف يعمل بها ال مووطa)ة0.‏ 


f Dearie Database Configuration Assistant, Step 5 ol 8: Database Coarvection Options E اول‎ = 


Seletl lhe rode in which yO warl yolar dalab ase lo operate bf Hefa : 


# Dedicaled Server Mode 
For each client connection the dialatase will allocabe a resoarce dedicated iû serving only irat 
thant Use is madê when heê umber ûf löfal lîn con nıetûnš Î êıpêtêd lû bê šmıãll ûr 
hên tlleritš will bla making pêrsišlênk Îong-runining requests iû hê databãšê. 


 Bhared Server Mada 


1ِ 3 

Several cllent eornnsctons share a dalabase-allocaled pool of reswurces. Use this mode‏ ۳ ا 

whan more hari a ral number of USErS named ta coriniect bo the databa ze slmilltans oUrsly‏ م 
while efficiently utilizing Byam resources. The Oracle rmulti-ihreaded serwer fe alure will he‏ 
enabled,‏ 


tarrecliofigs Fafa 


Finish j 


Caneel j] Help i  Batk 


رسم 3.4 


WP Oradle Database Configuration Assistant, Step 6 ol 8 : Initializalioiı Par aîıebers 


mamo || Arche | DBSzing | File Locations 


T Tpiral 
Max. nû, of cûneurênliy tûr fre clad ığêš: 20 


70 


Percentage of physical rrermwory (343 MÊ) for ûOrazle: 


Dalbase Type: 


Ell 


IHERIEOHOR OF HEA. 


ë Çusbom 
Shared Fool: 38 a (MENS _~ 
Buff Cathe! 30 ETH 
Jawa Fool! 0 2 Memes 7~ 


Total Merrrory for Oracle: 36 Bl Bytes 


All Inîtlalîzaîîon Farameletrs... 1 File Location VaNlARÎES 


Finish j 


Cancel 1 Help 1 


رسم 3.5 
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يتم بعد ذلك عرض اسماء الملفات الفيزيائية وال ومءءدمءم1طه٠‏ ومواقعها ولديك الخيار بحذف أو اضافة 


ملفات اخری. 
لاطا 


Database Storage 


Frorn hê Dataktašê Stofrağê pagê, Yû cani peti storage pararnêlers for ê dalalašê 
trio, This page displayê û feo Relinğ and summa sike mi E olur EIS] bo al OL 
o charg afi ir Hu follewirg objets 


» aniroiles 

» TablBBPaleS 

* Cialafileš 

» Rollbtatk Segments 
» Redê Lûğ rûypê 


From ary object type folder, clk Auld to craaie a new object To delete an objest, select the 
aperifle object from within the objec pa folder and click Rarmmve. 


Important: If yol selem a seed database lemplale, YOU will mot be able o add or remove 
dalafilss, lablesapapes, or rack sagments. Seleding a seed temiplake allows you 10 only 
change the following: 


» The rıarmıe of thre dafabiasê 
s» Deslînaiiorn of ihe dHatafiles 
» Coniroliles or log groups 


Fils Location Wariables... 
Hod Einish 


رسم 3.6 


E] Ganiralnilêë 


EHO Tablespatêš 

MO Dalailis 
EMDRoIIbaEk Sogn: 
EMIRedo Log GFOUpš 


Ad | | FEOF 


Canêtêl Help 


في المرحلة التالية يتم اختيار نوعية التكوينء هل تريد تكوين”#ء4طهه أو تريد تكوين فقط قالب 
"ateاemp‏ "ا" أو هل ترید تکوین جمل وام ذاء؟ Q1‏ ۹الت یمٹگنٴاستخدامھا مع امر 


.CREATE DATABASE 


EE 


Selerel me folowing database creation options: 


ê Creal Dalahaeê 
[` gare aş a Dalabaşe Termplalt 


Name: em” 


OGeBtri pil on: 


1` Genêralê Dafabãşê Creallûn Strips 


Desnalion TET TET TTT 
Bireclory: CoracleTarad 


admired atals crip ls 


BOWSE 


Û Bak Heat 


رسم 3.7 


56 


Helm Î 
ا‎ 


f ;arclr Database Configuration Assistant, Step 8 af 8 : Creation OpthomEs 


Cancel ا‎ 


:CONFIGURE DATABASE OPTIONS 


يمكن تعديل ال مءوطهاه( التي تم تكوينها سابقاً من ناحية ال و6 ں٤ه٥۴‏ ٥1ء١0‏ والبيئة التي تعمل عليها 
„(Dedicated Server yl Shared Server)‏ 


:DELETE A DATABASE 


لحذف مو4 طو)ه تم تكوينها سابقاً 


:MANAGE A TEMPLATE 


یمکن استخدامها لتکوین قالب "٥)14م "۲٠.‏ أو لحذف قالب "٥٤14م "۲٥‏ موجود. عند تكوين قالب 
"ateاpصe‏ ا" جدید یمکن الاختیار بین ثلات خيارات هي: 


من قالب "٥٤ھامص٥۲"‏ أخر موجود» اذ يمكن تعديل مواصفات القالب "٥)دام "۲٤٥‏ لصنع قالب 
"ateاemp""‏ جدید. 

ه من مواصفات ء1 طه)ھ( موجودق(تم تکوینها سابقاً) › اذ یمکن تکوین قالب "٥٤ھام‏ ص٤۲"‏ 
مشابه لمواصفات ال ٥ء4‏ ط544 ولکنادون ملفات ال و٥۴ 4٤4‏ 0. 

ه من موو طهtه(‏ موجودة» اذ يمكنتكۆين نسخة مطابقة ل موو طوt)ه0‏ موجودة مع ال وا54 
6 وجميع البيانات. 


BW ;Oracle Database Conliguration Assistant, Step ã of B : Template Managemen ا٥ا‎ × 


Select tha lEemplate marağjefrent operation au want io perform: 
® Creale a dalabase lermplale 
# From an existing template 


T From af Exising dalabasê (sirtê ûnilyj 
The termplale will contain zirucîural imiormation abouî ihe source database including 
dafabase opilons, tablespaces, datafiles, and Inîllallzalon paranvelers specifled in fhe 
source database, lser defined schemas and fhelr dala will nol be part of fhe creailed 
Template, 

` From an existing database (sinychurg aş well a3 data) 
The terr plate will carıtaîn he siricbural information a5 well as physical dalafiles specifed 
in the sorte database. Dalabaseês treated using Such aã lerıplalê will be idanlital lo tre 
soiree dalabase. sar defined schemas and helî dala will be part ûf lhe lemıplabe. 


"` Delels a database lemıplale 


Ganrel | Help | 4 Back | Nel 
3.8 رسم‎ 
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CREATE A DATABASE MANUALLY 


يمكن تكوين ال وط هه بطريقة يدوية باستخدام !لمر .CREATE DATABASE‏ 
الخطوات المتبعة تتلخص بالتالي: 


.Database Jly Instance Û تحديد اسم‎ 

تحدید ال Character Se٤‏ aseطataط‏ التي سوف نتطرق لها لاحقاً في فصل أخر. 
تجjı‏ مذف .Initialization Parameter File J|‏ 

تشغيل ال مه ط هه في الوضعیة N1‏ ا0 ›NNOM‏ عبر ال 84 SD$؟¥S.‏ 

.CREATE DATABASE !لمر‎ ةlتک‎ 

. Data Dictionary Û| jڍyكîl‎ SQL SCRIPTS ÛJ تشغيل‎ 


ملاحظة: اذا كنت تقوم بتكوين ال مو ط٤(‏ على نظام ال N]×‏ ل یجد تحدید ما یعرف یاسم ال 
ling Environmental Variables‏ : 


.'"آ٣ ۴ہ‎ ۲۲٥۲" هو الموقع "راه)ء٥1۲٥" الذي يحوي کل ملفات الأوراکل‎ :0RACLE_BASE 
وهنا يتم تخزين كل نسخ الأوراكل المختلفه "ور مذوإمء۷".‎ 


.Oracle Software ÛI gage :ORACLE_HOME 


:0RACLE_SID‏ تحدد اسم ال ٥e‏ ھ)8 ا ۆالذي یجب ان یکون غیر متشابه مع اسم ٥٥ہ‏ ه٤ی"!]‏ آخر. 


.'"5efھں[٤" غیر التي تم تحدیدھا مسبقاً‎ "(atabe Character Se)" لتحدید‎ :٥RA_ N3 


۳ : مواقع برامج الأوراکل مثل ال 8ا1۲ @8» وان#المفترض ان تکون 
.SORACLE_HOME\bin‏ 


:1D  L[]BRARY_ PATH‏ ملفات أخری تسمی es‏ ]ز۴ 1r ary‏ eاOrac‏ وعادۃ ما تکون 
.SORACLE_ HOMEI\lib‏ 


يمكن تكوين مو4ط و٤4(‏ بشكل يدوى باستخدام القاعدة التالية: 


CREATE DATABASE [name of database] 
[CONTROLFILE REUSE] 
[LOGFILE [GROUP number] C1 


[MAXLOGFILES number] 
MAXLOGMEMBERS number] 
MAXLOGHISTORY number] 
MAXDATAFILES number] 
MAXINSTANCES number] 
ARCHIVELOG | NOARCHIVELOG] 
CHARACTER SET char] 
[NATIONAL CHARACTER SET char] 


[ 
[ 
[ 
[ 
[ 
[ 


[DATAFILE C1 [C2]] 

[DEFAULT TEMPORARY TABLESPACE tablespace_name C1 [C3]] 
[UNDO TABLESPACE tablespace name DATAFILE C1 [C2]] 

[SET TIME _ ZONE [time_zone region]] 
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أما ال الرموز ال €1 K3.€2‏ فترمز الى جزء من القاعدة تم تخفيفة الى رموز لسهولة قراءة القاعدة: 
'"filename' [SIZE number] [K | M] [REUSE] =C1‏ 


[AUTOEXTEND OFF | ON [NEXT number [K | M]]=C2 
[MAXSIZE UNLIMITED | number [K | M]]] 


EXTENT MANAGEMENT LOCAL UNIFORM [SIZE number] [K | M] =C3 
اي انه في الجملة الثالثة تكون القاعدة:‎ 


[LOGFILE [GROUP number] 'filename' [SIZE number] [K | M] [REUSE] 


ملاحظة: جملة ال CREA E D۸1۸ BASE‏ هي الجملة الإلزامية الوحيدة و الباقي اختياري. 


ملاحظة2: عند عدم استخدام كلمة ال S17۴٤‏ يجب استخدام كلمة ال S۴‏ ل ۸٤‏ والعکس صحيح. 
أما أوامر القاعدة فهي : 


:]name of database]‏ اسم ال مsوطوtهD‏ المراد تكوينه. في حال عدم كتابته يؤخذ قيمة العامل 
.DB_NAME‏ 

B0N "ROLFILE REUSE] *‏ ]یمکن استخدامھا لطلب اعادۃ استخدام "0e Wr İ)٥'‏ 
ملفات ال Con t01 ۴1e‏ المعرفة في ال ]n¡itialiation Para meer ۴1e‏ عوضاً عن تکوین 
ملفات جديدة. 

:]MAXLOGFILES number] e‏ تحدد(الْعدد الأقصی لمجموعات ال 10g ۴6s‏ 8۵0 التي 
يمكن تكوينها في ال موو طه)د( على مدى حياةرالمء4طه)04) العدد الأدنى هو 2. 

:]MAXLOGMEMBERS number] *‏ تحدداالعدڈ الأقصی لملفات ال ۸d0 0g‏ ضمن 
المجموعات. 

:][M AX LOGHISTORY number] *‏ تحدد عدد Archived 0g ۴¡[e8@(‏ التي تسخدم في 
عılnة .Media Recovery J|‏ 

U۲0 EXTEND] *‏ ۸]: سوف نتطرق لھا لاحقاً. 

:]MAXDATAFILES] °‏ تحدد العدد الأقصی من ال ۴1٥‏ و( الذي يمكن تكوينه على مدى 
حياة .Database Jı‏ 

:]MAXINSTANCES]‏ تحدد العدد الأقصى من ال ومعم و٤ءم!]‏ الذين يستطيعون العمل على ال 
6 في نفس الوقت. 

:]CHAR ACTER SET char]‏ سوف نتطرق لھا لاحقاً. 

:]NNA]0 N A1 CHARACTER SET] °‏ سوف نتطرق لھا لاحقاً. 

Default Temporary ÛJI jıgSîl :[DEFAULT TEMPORARY TABLESPACE] 
التي سوف نتطرق لها لاحقاًء اذا لم تحدد يقوم الأوراكل بتكوينها للمستخدم.‎ rablespace 

:][U€[NDO TABLESPACE] *‏ لتکوین ال ceھےsp٥1‏ اھ٣‏ 40 €n‏ التي سوف نتطرق لھا لاحقاً. 

.D4غ4طھe تحدید وقت ال‎ :]SE۲ "]|ME_ZONE] 
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مثال تطبيقي 3.1: 


CREATE DATABASE db01 

CONTROLFILE REUSE 

LOGFILE 

GROUP 1 ('C: \oraclelora92\oradata\db01\log101.log') SIZE 10M 
GROUP 2 ('C: \ oracle\ora92\oradata\db01\log201.1og') SIZE 10M 
GROUP 3 ('C: \ oracle\ora92\oradata\db01\log301.1log') SIZE 10M 
MAXLOGFILES 4 

MAXLOGMEMBERS 2 

MAXLOGHISTORY 0 

MAXDATAFILES 254 

MAXINSTANCES 2 

ARCHIVELOG 

CHARACTER SET AL32UTEFS8 

NATIONAL CHARACTER SET AL16UTF16 

DATAFILE 'C: \oraclelora92\oradata\db01\system01.dbf' SIZE 100M 
AUTOEXTEND ON NEXT 5M MAXSIZE UNLIMITED 

UNDO TABLESPACE UNDOO01 

DATAFILE 'C: \oracle\lora92\oradata\db01\undg01.dbf' SIZE 40M 
DEFAULT TEMPORARY TABLESPACE TEMPODTEMPFILE 
'C: \oracle\lora92\oradata\db01\temp01.dbf' SIZE 20M 

EXTENT MANAGEMENT LOCAL UNIFORM SIZE 128K 

SET TIME_ZONE = 'CANADA /YUKON! 
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الأخطاء التى قد تؤدي الى فشل تكوين ال مووطه٤ه0‏ بشكل بدىئ: 


.S@ا أخطاء في كتابة جمل ال‎ ٠ 
ه طب تكوين ملفات موجودة مسبقا (تأكد من ان اسم الملف غير مستخدم)‎ 
."Operating Sy" ه مشاكل أو اخطاء ناتجة من نظام التشغيل‎ 


لأعادة تكوين ال مووطه)ه0 بعد محاولة فاشلة يجب: 


.]nst4 "ce اغلاق ال‎ 

حذف أي ملفات تکونت من ال 5۸1۸8۸5۴ )PREA €٤‏ التي فشلت. 

تصحيح سبب الفشل › مثل تعديل جملة ال 5Q1‏ التي تحوي أخطاء. 

تشغیل ال م٥‏ واء"[ في وضعية ال N0N ٥0ا0 N1‏ والقیام تکوین ال مء2ط هه( من جدید. 


ملاحظة: لا يتكون ال راهم ٠ء51‏ واه بعد الانتهاء من تكوين ال مsوطه٤ه(‏ بشكل يدوي» ولكن يتم 
تكyيù .VŞDATAFILE Û! Jûa Dynamic Views J|‏ 


تذكر: تغيير كلمة السر لكل من المستخدمين S۷8‏ و 9۷5S۲ ٤۷‏ لأخذ الأمان. 


تذکر: ان استخدام ال Oracle Managed Files (OMF)‏ يسهل عملیة تکوین ال seھطھ†Da.‏ 
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DATA DICTIONARY 


يعتبر ال رها¡( Da‏ أحد أهم مكونات ال مءوط ه0 اذ يتكون من مجموعة من ال 16s‏ ط۲ وال 
التي تحتوي معلومات قيمة عن ال مووطه)ه0. تستخدم ال رور هذا و٤(‏ لقراءة البيانات 
فقط ولا يمكن تعديل بياناتها بواسطة ال ۰084 ولكن يقوم ال ماءهإ0 بتعديل البيانات الموجودة عند حدوث 
أوامر ال .Data Definition Language (DD)‏ یستخدم الأوراکل ال راھ ہذاc D4)‏ ایضاً عند 
طلب المستخدم الدخول الى Database ÛJI‏ < | يقوم بالتأکد من وجود اسم المستخدم وبيانات المستخدم مثل 
.User Privileges ÛJI‏ 


یتکون ال راھ ها¡( 4)4( من عنصرین هما: 


:B ASE "ABLES‏ یتم تخزین بیانات حول ال مط هه( في ال 16ا۲۵ 4۵ 8. تعتبر ول 
جزء "٥زط0"‏ من ال م4sطه)ه(‏ يتم تكوينه» ويتم تكوينها بشكل أتوماتيكي من قبل الأوراكل 
باستخدام الملف ")م ذء؟" المسمی باسم وط.[ی. لا يجب تعديل ال وء[اطه١‏ م844 أوالعبث بها 
لأنها ضرورية لتشغيل ال مووطه)ه0/ ولكن يمكن تعديل واحدة فقط وهي ال ۸5$ › مع العلم أنه 
يتم تخزین البيانات في ال 16s‏ اه م84 بشكل مشفر. 

0N ARY [ENS‏ ]1 ]1 : تقوم بتلخيص وترتيب بيانات المخزنة في ال وماطه1 م844 لكي 
تسهل استخراج البيانات و قرائتها) يتم تكوينها باستخدام الملف ")مذء؟" المسمى باسم 
.catalog.sql‏ 


:Data Dictionary Û| ٽlنlڊ‎ 


يوفر ال رإه«هاء¡ وه بيانات مهمة حول: 


Tables, Indexes, J| Jia Database J| "Objec†s'" معلومات تفصيلية حول جميع عناصر‎ 
و غيرھا.‎ Views, Synonyms, Data files, Control Files 


بيانات حول المساحة المشغولة والمساحة الفارغة في ال مووطه)ة0. 
بيانات حول المستخدمين "'١إمءلا"'".‏ 

بيانات تفصيلية لل ومعم‌]1ز آ۴ و ال وم801 الممنوحة لكل مستخدم. 
بيانات حول ال ع« ں۸ التي سوف نتطرق لها في فصل أخر. 


. Integrity Constraint ÛJI بياناٽ حول‎ 
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QUERYING DATA DICTIONARY 


تتوزع ال وس۷1 راه« ماع1 الى ثلاث مجموعات عي: 


_8۸(: تحتوي ال ع۷1 على جميع بيانات العناصر "ء٤ءز(0"‏ في ال ۾4sط 04٤4‏ وهي 
خاصة لل D8۸‏ و کل مستخدم لدیه ال وه عم 1ر1٥‏ اللازمة للدخول الى بياناتها. 


٠ه‏ _11: تحتوي على بيانات حول جميع العناصر "ءءء زط0" التي يستطيع المستخدم استخراج 
البيانات منهاء سواء ما كان منها ضمن ال .1ء5 الخاصة بالمستخدم أو مستخدمين أخرين أو 
.Public Schema ÛJI‏ 

15SER _ ٠‏ : تحتوي على بيانات حول العناصر "٠زط0"‏ التي يملكها المستخدم (أي العناصر في 
ال هع طء؟ الخاصه بالمستخدم). 


يمكن معرفة جميع ال وسء۷1 المتوفرة في ال رادم اء¡ ود( من خلال البيانات المعروضة من ال 
.DICTIONARY view‏ 

مثال تطبيقي 3.2: 

SELECT * FROM DBA_OBJECTS; 

SELECT * FROM ALL OBJECTS; 

SELECT * FROM USER_OBJECTS; 


SELECT * FROM DICTIONARY; 


DYNAMIC PERFORMANCE 
بتسجیل بیانات حول عمل ال مھ طه0t في‎ 0۲4٥1۵ S۷٥۲ طوال فترة عمل ال مئ4ط ه٤۰04 یقوم‎ 
الذاكرة على شكل وع1طه١ وعند اغلاق ال مووط واه أو اغلاق السيرفر تضيع البيانات من الذاكرة.‎ 
من ضمن ال 3٥1ء5 5۷8› وهي تستخدم بشکل اساسي‎ Dynamic Performance View تعتبر ال‎ 
عليھا.‎ Data Manipulation Language(DML) لمراقبة ال مووطه د ولا يسمح القيام بأوامر‎ 


لمعرفة ال و٥۷‏ المتوفرة يمکن استخدام ›V$FIXED_ TABLE‏ ولمعرفة ال وص uاهC٤‏ ضمن ال 
.VŞINSTANCE pدختwاl Views‏ 


. ¥$ jزمرلاب‎ hynamic Performance Views Ji jaری ملاحظة:‎ 
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الفمسل الر ايع 


ملفات الكننرول و الريدو لوج 


CONTROL & REDO LOG FILES 


CONTROL FILE 


یعتبر ٤٥٥,٤۲٥1 ۴1٥‏ ضروري جد لتشغیل وعمل ال مھ ط هه۰0 حیث تتم قرائته من قبل ال ما04 
إمServ‏ قبل بدء تشغيل ال مءوطه٤4(/‏ اذ يحتوي على بيانات مهمة حول ال مءوطه)ه مثل اسماء 
ومواقع ملفات ال .D4a ۴1٥‏ تتم تغیر بیاناتھ أو تجدیدھا ")ےل ملا" عبر ال Seer‏ 41ا0 فقط › 
اذ لا يستطيع أي مستخدم أو ال D84‏ القيام بهذه المهمة. 

یتم تکوین ال ۴1٥‏ 1٥٤رہ‏ بعد تکوین ال se‏ طھ٤ھD‏ مباشرة ولا یستطیع ال C٥۸٤1 ۴1٥‏ الواحد 
العمل على أكثر من مووطه)ه( واحدة › ويلزم ۴1٥‏ 01إ)٠)‏ واحد فقط على الأقل لتشغيل ال eووطه)54‏ 


ملاحظة: تسمى عملية تكوين أكثر من نسخة متطابقة من ملفات ال C٥٤٥1 ۴1٥‏ (ينطبق الحال على ال 
ع0ا R ed0‏ ايضا) بعملية ال ×م1م اا1 » ويفضل توزيعها على مواقع أو اقراص صلبة مختلفة. 


ملاحظة2: ملفات ال ۴1٥s‏ 1٥۲٤رهC‏ من نوعية ال رھہ¡8. 
تذکر: تتم قراءة ملفات ال ۴1۲ ٤٥)٣٠‏ رفي مرحلة ال .Mou n)‏ 


تذکر2: ملف ال SP ۴1٤‏ من نو عیۂ ر٥٣‏ ھہ8i.‏ 


یوجد عوامل ''۶ا٥)e‏ ,4و۴" تحدد حجم ال ٤01 ۴11e‏ ہ €٥‏ وھی: 


MAXLOGFILES 
MAXLOGMEMBERS 
MAXLOGHISTORY 
MAXINSTANCES 
MAXDATAFILES 


یحتوی ال ٥ا۴‏ 01إ٤ره٥‏ على البيانات التالية: 


.Control File ÛJI qi التي يعمل‎ «ata طوaوم اسم ال‎ 

تاریخ وتوقیت تکوین ال seوطه)04.‏ 

.Redo Log ÛJI و‎ Data ۴¡[¢s اسماء ومواقع ملفات ال‎ 

.Tablespaces JI slaw 

.Checkpoint Û| معلومات حول‎ 

.Archived Log File Ja معلومات‎ 

معلومات حول عملیة ال up‏ )4 8. 

توقیت بدء و توقف ال 1d0 Seg")‏ ا. 

الرقم الحالي ل 10g Sequence Number‏ والذي یتم تخزینه عند حدوث طعt¡سS‏ 08ا. 


تذكر: يحتوي ال ۽a1erS15.10۾‏ ايض J|ذآJ .Log Sequence Number‏ 
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MULTIPLEXING CONTROL FILES 


للحماية من أية خلل قد يحدث لل موو ط هاه نتيجة تعطل ال ٥ذ۴‏ [0٣٤رهC‏ ينصح بشدة بالقيام بعملية ال 
Multiplex‏ لل ۴1e‏ 1اtroاCn‏ بيحث يتم تخزين النسخ المتطابقة في مواقع تخزين مختلفة لكي يتسنى 
استعادة ۴1۲ ٥٥.٤۲٥1‏ في حال تعطله أو ضياع بياناته. 

للقیام بعملیة ال s٥1من)اںM‏ یجب استخدام إما ال SP ۴1٤‏ أو ال ini).0٣4‏ . 


ملاحظة: یمکن عمل ثمانیة نسخ لل .C٥۸)٣01 ۴1٥‏ 


:MULTIPLEXING USING SPFILE 
يجب إتباع الخطوات التالية:‎ P۴1۴٤ بواسطة ال‎ Contro1 File Multi pاes للقیام ب‎ 
كما في المثل التالي:‎ S۶۴1٤ تغییر ملف ال‎ 
ALTER SYSTEM SET CONTROL_FILES = 
(...lora01\oradata\db01\ctr001.ct1', '...lora02\oradata\db01\ctr002.ctl', 
'...lora03\oradata\db01\ctr003.ctl', '...lora04ofFadatd\db01\ctr004.ct1') 
SCOPE=SPFILE; 


ه لكي تتم التغيرات يجب اغلاق ال ط464( بكتابة التالي: 
SHUTDOWN;‏ 


نسخ ملف ال ٥٠۸)٣01 ۴1٥‏ الى المواقع التي جدكت بالنقطة الأولى (القيام بعملية النسخ كما في 
نظام التشغيل › اي في الویندوز يستخدم الفأرة مع ٥0۴¥‏ و €آPAS.‏ 


٠‏ تشغيل ال موو طه)ه بكتابة التالي: 
STARTUP‏ 


:MULTIPLEXING USING init.ora 
بواسطة ال aإ0.٤زم يجب إتباع الخطوات التالية:‎ Contro1 File Multip]‌ی للقیام ب‎ 


ه يجب اغلاق ال مووطهاه بكتابة التالي: 
SHUTDOWN;‏ 


e‏ نسخ ملف Control File JÛ|‏ الى المواقع الجديدة التي سوف تحدد في النقطة الثالثة. 
٠‏ تعديل العامل "Parameter"‏ ROL_FILESآ0N()‏ في ملف ال ۲4٥.)نم‏ كما في المثال: 
CONTROL_ FILES =(...\disk1\ctr01.ctl, ...\disk2\ctr02.ct1)‏ 


تشغیل ال seھطD4)4.‏ 
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ملاحظة. استخدام الثلاث نقاط )...( في المثال السابق للاختصار فقط, 
:USING OMF‏ 


یمکن تسھیل إدارة ملفات ال ٥٥)٥1 ۴1e‏ باستخدام ال Managed F۴ ¡1es‏ eاacا0.‏ یمکن تکوین ال 
Contro1 Files‏ طبقاً لطریقة ال M۴‏ بشكل أتوماتيكي عند تكوین ال م4 طه)ه اذا لم يتم تحديد العامل 
Parameter Files JI yê CONTROL_FILES "Parameter"‏ iationاnitia]‏ وتم تحدید 
.DB_CREATE ONLINE LOG DEST _ n OMF JI "Parameters" Jale‏ 

بعد تکوین ال ٥٥۸٤۲٥1 ۴1٥‏ بطریقة ال M۴‏ یجب تسجیل اسم وموقع ال ۴1۲ ٥٥۸٤۲٥1‏ في ال 
PFE‏ » اما اذا کنت تستخدم ال 9P ۴1۴٤‏ فإن الاسماء تسجل بشکل اتوماتیکي. 


:DATA DICTIONARY & CONTROL FILE 
عبر:‎ Data Dictionary Ûا| من‎ Contr 01 ۴ ¡1e یمکن استخراج بیانات ال‎ 


:Y$ŞCONTROLFILE ®‏ تعرض اسماء ال Con tr01 ۴ ¡1es‏ والحالة الحالية )§S1۸115(‏ اذ 
انها دانما فارغة إلا في حال ضیاع ملف من ملفات ال ٥٥۸٤٣٣1 ۴1e‏ فتصبح .1IN۷۸ 11D‏ 


SELECT STATUS, NAME FROMeVŞEONTROLFILE; 


:ŞPARA METER‏ تعرض ياء وقیم ''وعں[ ے۷" جمیع العوامل ع۸٣۶۸"‏ من 
ضمنھا طبع .Control Files JI‏ 


SELECT NAME, VALUE FROM VŞPARAMETER 
WHERE NAME = 'control_files'; 


:6CONTROLFILE_RECORD_SECTION °‏ تعرض بيانات عن الأجزاء المختلفة من 
.Control File Û!‏ 


SELECT TYPE, RECORD_SIZE, RECORDS_TOTAL, RECORD_USED 
FROM V$ŞCONTROLFILE_RECORD_SECTION; 


C0۸٤01 یمکن استخدام هذه للحصول علی مواقع واسماء ال وم۴1‎ : SHOW PARAMTER 


SHOW PARAMETER CONTROL FILES; 


ملاحظة: یمكن الحصول ایضاً علی اسماء ال C۸٤٥1 ۴s‏ بعد تکوینها من ملف ال ع41۵۲۲۹10.[0. 
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REDO LOG FILES 


تعتبر ملفات ال وم1 0ء8 ضرورية جداً لعمل ال مووطه)ه ٠‏ اذ يتم تخزين كل ما جرى ويجري على 
البيانات من تغيرات لکي يتم استعادة البيانات "Recovery"‏ في حالة حدوث ضياع للبيانات عند حدوث عطل 
مفاجیئ. تنقسم ملفات ال ع10 8٥40‏ الى مجموعات "60u"‏ كل مجموعة تحوي أعضاء 
"Members"‏ و الأعضاء "١ء "em‏ ضمن المجموعة الواحدة عبارة عن نسخ متطابقة 
"زمه" تحوي على نفس البيانات ويتم نقل البيانات لها في نفس الوقت. 
يتطلب الأوراكل على الأقل مجموعتین من مجموعات ال [0g ۴1٥s‏ ٥ء۸‏ وکل عضو "۲ءطص ء۷" ضمن 
المجموعة يكون له نفس الحجم وذات .Log Sequence Number Û‏ 
يقوم الأوراكل بواسطة ال 1G R‏ بنقل بيlنات Redo Log Files JI ll Redo Log Buffer J|‏ حیث 
تتم الكتابة على مجموعة واحدة فقط وعندما تمتلئ المجموعة الأولى يقوم ال ۷R‏ 16 بكتابة البيانات في 
المجموعة الثانية وبعد إمتلاء المجموعة الأخيرة يعود ال ۷R‏ 16 بالكتابة في المجموعة الأولى » وتسمى 
هذه العملية بال طء٤زس؟S‏ ع٠1‏ وتسمى المجموعة التي يتم نقل البيانات لها باسم المجموعة الحالية أو 
."Current Online Redo Log Group"‏ 


ملاحظة: يمكن تحديد الحد الأعلى للمجموعات و الأعضاء بواسطة MAXLOGMEM BERS‏ و 
.CREATE DATABASE Û ةlaج „ê MAXLOGFILES‏ 


تذکر: یتم تخزین بيانات حول ال b05 wite‏ في „Alert Log File Û‏ 


LOG SMITCH LOG SMATCH 


member 1 


GROUPZ SROUP3 


کل مجمو عة ۴1e‏ ع10 Red‏ معرفة برقم ممیز یسمی Segue 1ce Nu‏ ع0[ یمنحھ الأوراکل لکل 
مجموعة عند بداية كتابة البیانات بها حيث يتم تجدید الرقم "٤٤اس‏ ام0۷" كل مرة يتم إعادة استخدام 
المجموعة. 
تذکر: يتم تخjıj [0g Sequence Number‏ في: 

Control File 

Data Files Header 
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Alert Log File ° 


تعرضنا لل "هم )ء٥1٥‏ في الفصل الأول وذكرنا انه يقوم بكتابة ال 10g Sequence Number‏ في ال 
.C0ntro1 File‏ ونتطرق لل ٤inمم‏ )عط مرة أخرى لأن العلاقة بین Log Jly Checkpoint J|‏ 
Switch‏ متزامنة بحیث عند حودث ال طعt¡سS‏ ع0[ تحدث عملي ال ٤م‏ ¡ەمCheck€٥.‏ ويقوم Alert Û‏ 
[0g F6‏ بتخزین معلومات حول ال ٤ہزمم‏ )ط٥‏ کما یقوم بذلك مع ال طc)اس؟‏ ع٥[‏ ولکن یجب وضع 
العامل "Para meer"‏ التاذأي 106G CHECKPONT_ TO_ALERT‏ في حالۂ ue‏ ۲ عکس الحالة 
الإفتراضية ")[uوfء5"‏ وهي مء[ه۴. 
يمكن ان تحدث عملية ال ٤م‏ زمم C1)‏ عند: 

.Log Swit حدوث عملية‎ 

.ABORT عند إغلاق ال مووطه٤هD بأي حالة عدا ال‎ ٠ 


٠‏ عندما يحدد العام ۴۸S۲ _START_MTTR_TARGET "Parameter"‏ الذي یحدد کمیة 
البیانات المتغیرة '' B٤٣١‏ را" التي یستطیع ال (8W‏ کتابتها. 


.4.1 كما في المثال‎ 5Q1 عندما طلب ال 84( يمكن القيام بهابكتابة جملة‎ ٠ 
ALTER TABLESPACE OFFLINE NORMA. التالي:‎ 8Q1 عندما تكتب جملة ال‎ ٠ 
.ALTER TABLESPACE READ ONLY :ةيلlتll‎ SQ عندما تكتب جملة ال‎ ٠ 


.ALTER TABLESPACE BEGIN BACKUP :ةيllتl‎ SQ J| عندما تكتب جملة‎ 


مثال تطبيقي 4.1: 
للقيام بعملية ال ٤رزمم‏ ٤ء1٤‏ بواسطة ال SQ‏ يجب كتابة التالي: 
ALTER SYSTEM CHECKPOINT;‏ 


اذا تم تحديد العامل "٣ع)ء0ص "Para‏ 
FAST_START_MTTR_TARGET = 400‏ 


يدل على عملية ال رم هءءR‏ يجب أن لا يزيد وقتها عن 400 ثانية حيث أن من ضمن عملية ال 
.Log Switch J| alae Checkpoint Û| alae Recovery‏ 


يمكن آن يتم طلب عملية ال طء٤زس؟‏ ع10 ايضاً بواسطة ال Q1‏ عبر التالي: 


ALTER SYSTEM SWITCH LOGFILE; 
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MAINTAINING REDO LOG FILES 


سوف نتطرق الى عدد من المهام التي یمکن اجرائھا لل و٥۴‏ ع10 R٥۵١‏ لحمایتھا أو لتعدیلها. 
:MULTIPLEXING‏ 


لحماية ال ase‏ ط وھ( یجب القیام بعملية ال ×[مذ)اںM‏ علی ال 6ا۴ ۽٥[ R٥۵0‏ › بحیث یقوم ال 
6W۷R‏ 1 بكتابة ذات البيانات على النسخ المتشابه في نفس الوقت. كل النسخ المتشابه تكون ضمن مجموعة 
"Grup"‏ و يطلق على النسخ المتشابه اسم وء طا_ء. يفضل فصل النسخ المتشابه عن بعض وابقائها 
في موقع مختلف أو على قرص صلب مختلف (أو أي وسيلة لحفظ البيانات) كما في الرسم 4.1 يظهرأن 
الأعضاء (۲2ءطnءM‏ , 1إءمMemb)‏ في ذات المجموعة على قرصين مختلفين (k2ء¡0‏ ,1ء0i).‏ 

في حال عدم توفر أي عضو "١طد"‏ من أي مجموعة لنقل البيانات إليه يتم اغلاق ال #ءوطو٤54‏ 
تب عمılة .Instance Jİ Recovery‏ [ 

يمكن تكوين أكثر من مجموعة من مجموعات ال ۴1 ع10 8٠40‏ عند تكوين ال #sوطه٤ه(‏ أو يمكن 
اضافة مجموعة أخرى لاحقاً. 


نقاط مهمة فى عملي Multiplex J|‏ 


e‏ ينصح بتفريق الأعضاء ضمن الكجموجة الواحدة الى مواقع أو اقراص صلبة مختلفةء لكي لا يحدث 
أغلاق لل مووطهاه في حال تعطل/القرص الصلب الذي يحوي الملفات. 


ينصح بتفریق ال Red 10g ۴es‏ ineاOn‏ عن ال Archived 10g ۴es‏ الی اقراص 
مختلفة أو مواقع مختلفة لكي لا يحدث تداخل بين عمل ال 1G WR‏ و .ARCn Û‏ 


٠‏ ينصح بتفريق ملفات ال عم 8٠4٠‏ و ملفات ال ۴16s‏ و٤(‏ الى مواقع أو اقراص مختلفةء لكي 
لا یحدث تداخل بین .LGWR Jl DBW n Û‏ 


:SIZING ONLINE REDO LOG FILES 
ھو 8× 50 › ما اکبر حجم ھو آکبر حجم یسمح بھ‎ ۸٤۵٥ عہ.1‎ ۴٥ صغر حجم یمکن ان یکون علیة ال‎ 
٤ [ .)70N]× نظام التشغيل (مثل ویندوز أو‎ 
یمکن لل 8۸( تحدید حجم ال و٥۴1 ع0 40ء8 بالأخذ بالمعطيات التالية:‎ 
.S)ه١وعم‎ (م۷٤ ه الجحم المتوفر على القرص الصلب أو أي‎ 
التي يمكن أن تحدث.‎ Checkpoint) و ال‎ 10g Swit عدد مرات ال‎ 


ه الحجم المتوقع لل وما) ع ل٠8‏ والذي يعتمد على العمليات التي تجري على ال مئوطو)4و5 
والتي تؤدي الى تغيير البيانات. 
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:ADDING ONLINE GROUP 
:4.2 في حال وجد ال 84( أن ال مووطه)ه بحاجة الى مجموعة جديدة › يمكن تكوينها كما في المثال‎ 
:4.2 مثال تطبيقي‎ 


ALTER DATABASE ADD LOGFILE GROUP 4 
("...loradata\dbO01\log11.log' , '...loradata\ldb02\log12.log') SIZE SM; 


:ADDING ONLINE MEMBER 
يمكن اضافة أعضاء جدد للمجموعات الموجودة باستخدام القاعدة التالية:‎ 


ALTER DATABASE [database's name] ADD LOGFILE MEMBER 
['filename' [REUSE] , 'filename! [REUSE], ....] 
TO [ GROUP number | (filename, ilename', ...); 


في حالة وجود اسم العضو على الجهاز وبنفسل الحجم (أي الملف موجود مسبقاً) يجب استخدام كلمة 
گ ۴E‏ اما بالنسبة الى الجملة الأخيرة فلديك أخياراان إما أن تذكر رقم المجموعة أو اسماء الأعضاء 
الحاليين في المجموعة التي تريد اضافة عضو جديد لها: 


ملاحظة: يمكن اضافة عضو جدید باستخدام .Console JI û Sîorage Manager J|‏ 
مثال تطبيقي 4.3: 


ALTER DATABASE ADD LOGFILE MEMBER 
'...loradata\db04\log41.log' TO GROUP 1, 
'...loradata\db04\log42.log' TO GROUP 2, 
'...loradata\db04\log43.log' TO GROUP 3, 
'...loradata\db04\log44.log' TO GROUP 4; 

أو بالطريقة الثانية: 
ALTER DATABASE ADD LOGFILE MEMBER‏ 
'...loradata\db04\log14.log'‏ 
TO ('...loradata\ldbO01\log11.log' , '...loradata\db02\log12.log' ,‏ 
'...loradata\db03\log13.log');‏ 


أو عبر ال م1مو ه٥‏ باتباع الخطوات التالية: 


ادخل الى ال 01eی" C٣0‏ عٹبر .Standalone‏ 

اضغط على اسم ال مءوطهه لكي تظهر نافذة تطلب من اسم المستخدم و كلمة السر. 
أدخل اسم المستخدم و كلمة السر مع التاكد من اختيار S۷5S584‏ عوضاً عن إوصإه.. 
اضغط على .Storage Manager J|‏ 

.Redo Log Groups JE !ضط‎ 

اكتب اسم العضو الجدید ثم اضغط رامم۸. 
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:DROPPING ONLINE LOG GROUP 


اذا أردت زيادة حجم أحدى مجموعات ال ع0 0ء8 يمكن ازالة المجموعة وتكوين مجموعة جديدة بحجم 
أكبر» حيث تستطيع ازالة مجموعة من مجموعات ال ع0 هلء 8R‏ باتباع القاعدة التالية: 


ALTER DATABASE [database' name] 
DROP LOGFILE [GROUP number | ("filename',....); 


يجب أن لا تكون المجموعة المزالة هي المجموعة الحالية "٤٠٠إإں٣"‏ أو ان تكون في وضعية م۷ذ)۸ بل 
يجب أن تكون في وضعية م۷إ)وم1. لا يسمح الأوراكل بحذف المجموعة اذا كان ذلك سوف يؤدي الى بقاء 
مجموعة واحدة فقط › اذ أن الأوراكل يحتاج على الأقل الى مجموعتین من مجموعات ال یذ۴ 8 .Redo‏ 
باتباع القاعدة السابقة يمكن حذف المجموعة من تعريف الأوراكل فقط > اما ملفات ال 0g‏ 0 الحقيقية 
الموجودة في الموقع المحدد (كما في المثال 43: ملف عه[ (log14.‏ لا تمسح ويجب حذفها بطريقة يدوية ' 
(كما في أوامر نظام التشغيل» في الويندوز استخدم مر مt٥[ء0).‏ 

مثال تطبيقي 4.4: 

ALTER DATABASE DROP LOGFILE GROUP 4; 

أو بذكر أسم أحد أعضاء المجموعة كما في المثال 4.3. 

يمكن أيضا تحويل حالة ال ۴|1۲ ed0 10g‏ 8R(الى‏ حالة ال اه1 بواسطة الجملة التالية: 


ALTER SYSTEM SWITCH LOGFILE; 


سوف نتطرق الى الحلات التي يمكن أن تكون عليها المجمو عة أو,العضو بعد قليل. 


:DROPPING ONLINE LOG MEMBER 


كما يمكن حذف مجموعة يمكن حذف عضو (أو أكثر) من المجموعة ولكن يجب أن يبقى على الأقل عضو فعال 
"Valid"‏ في المجموعة وإلا فإن أوراكل لن يسمح بعملية الحذف. كما في حذف المجموعة يجب أن لا يكون 
العضو هو العضو الحالي "Cunt"‏ و الملفات الفيزيائية لا تحذف من مكان تواجدها. يوجد حالة أخرى لا 
يسمح الأوراكل بحذف العضو» ذلك عندما يكون ال مووطه)ه( في حالة ال ماع ۷ ط٤٣۸‏ ولم يتم عمل 
طا للمجوعة التي ينتمى لها العضو. 


يمكن حذف عضو باتباع القاعدة التالية: 


ALTER DATABASE [database's name] 
DROP LOG MEMBER 'filename','filename',... 
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مثال تطبيقي 4.5: 


ALTER DATABASE DROP LOG MEMBER '...\loradata\db04\log4.log'; 


أو عبر ال م1مو ه٥‏ باتباع الخطوات التالية: 


ادخل الى ال Cons01¢‏ عڊر .Standalone‏ 

اضغط على اسم Database Û‏ لکي تظهر نافذة تطلب من اسم المستخدم و كلمة السر. 

أدخل اسم المستخدم و كلمة السر مع التاكد من اختيار S۷5258۸4‏ عوضاً عن إوإ۲ه٠..‏ 

.Storage Manager Û اضخط ع‎ 

اضغط على وم0uا‏ و0 R40‏ » ثم اختر العضو المراد حذفه واضعط على رسم سلة المهملات. 


:RENAMING LOG MEMBER 


اذا كنت تريد نقل عضو ٥٠"‏ ط٥1"‏ من موقع الى أخر أو تريد تغيير اسم العضو يجب اتباع التالي: 


اغلق ال 4e‏ طD4)4.‏ 
انسخ الملف الفيزيائي (الخاص بالعضن) الى الموقع الجديد (لنقل الملف) › أوقم بتغيير اسم الملف 
(لتغيير اسم الملف). 
قم بتشغيل ال ءءوطهه في حال أل .MOUNT‏ 
اكتب الجملة التالية 
ALTER DATABASE RENAME FIEE "old Filename' TO 'newFilename';‏ 


قم بتشغيل ال مووطه)ه( وقم بعملية مpںu)‏ ه8 لل ۴٥‏ 1٤ر٥٥‏ على اعتبار أن محتوياته 
تغیرت. 


:CLEARING ONLINE REDO LOG FILES 


في حال حدوث فساد للبيانات الموجودة داخل ملفات ال Log‏ 0 یمکن تنظیف الملفات باستخدام القاعدة 


التالية: 


. 
9 


ALTER DATABASE [database's name] 


CLEAR [UNARCHIVED] LOGFILE GROUP number | 'filename',... 


يمكن العدول عن عملية حذف ثم اضافة ملف ع0 8٠١0‏ بالقيام بتنظيف محتويات الملف لما توفره العملية 
من تسهيلات» اذ يمكن تنظيف مجموعة من مجموعات ال ع0[ R٥0‏ حتى ولو وجد مجموعتيين فقط 
وبداخل كل مجموعة عضو واحد فقط › ويمكن تنظيف المجموعة اذا كانت ال موو طو)ه0 في حالة ال 
Archive‏ ولم يحدث عملية مiطءإ۸‏ للمجموعة ولكن يجب استخدام كلمة R٣) 8]1۷٤(‏ N۸]ا‏ في 


القاعدة. 
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مثال تطبيقي 4.6: 
لتنظيف مجموعة من مجموعات ال عه ل٠8‏ اكتب التالي: 
ALTER DATABASE CLEAR LOGFILE GROUP 3;‏ 


أو بذكر اسماء أعضاء المجمو عة عوضاً عن المجموعة ورقمها كما جاء سابقاً. 


:USING OMF 
التي جاء شرحها سابقاً. بواسطة ال‎ 0M۴ ينصح باستخدام ال‎ Redo Log Fes لتسهيل عملية ادارة ال‎ 
تكوين عملية تكوين مجموعة جديدة أو حذف مجموعة أسهل و يقوم الأوراكل بحذف الملفات‎ 0M ۴ 
الفيزيائية الموجودة في موقع التخزين بشكل أتوتوماتيكي عند حذف أي مجموعة.‎ 
ي‎ DB_CREATE_ONLINE_LOG_DEST_ı یجب تحدید العمل‎ « OMF لاستخدام طريقة ال‎ 
يجب‎ Redo Log Files JI عل‎ Multiplex Ûا وللقيام بعملی4‎ ]nitialization Parameter File Û 
.5 ه۴ " برقم من 1 الى‎ ۲4 ٥)٥۲" استبدال ال م في العامل‎ 
:4.7 مثال تطبيقي‎ 
یج کتابة:‎ OM ۴ لحذف مجموعة تعتمد علی نظام ال‎ 

ALTER DATABASE DROP LOGFILE GROUP 3; 
أما لإضافة مجموعة يجب كتابة:‎ 

ALTER DATABASE ADD LOGFILE; 


حيث يقوم الأوراكل بتحديد رقم المجموعة واختيار اسماء الأعضاء أوتوماتيكيا. 


للقيام بعملية ال ×ع 1م ذ٤‏ اں[M‏ يجب تحديد التالي في :Initialization Parameter File J|‏ 
DB_CREATE_ONLINE_LOG_DEST_1='...\oradata\db01'"‏ 
DB_CREATE_ONLINE_LOG_DEST_2='...\oradata\db02"‏ 


DB_CREATE_ONLINE_LOG_DEST 3 ='...\oradata\db03' 
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:QUERYING LOG FILE INFORMATION 


يمكن الحصول على معلومات حول المجموعات و الأعضاء من خلال: 


V$LOG 
VSLOGFILE 


:VŞLOG 


تحتوى على بيانات حول المجموعات وأحجامها والحالة التي هي فيهاء يوجد 7 حالات يمكن أن تتواجد فيها 
المجموعهة وهم: 


10 : تدل على أن المجموعة لم تستخدم على الأطلاق في تخزين البيانات › غالبا ما يكون 
هذا النوع للمجموعات المضافة حديثاً. 

R0 في نقل بيانات ال‎ 11,6 ۷R تدل على المجموعة الحالية التي يستخدمها ال‎ :) UR RENT 
.Log Buffer 

.Rءء0۷ءإر تدل على أن المجموعة جاهزة لعملية ال‎ :۸ ۷٤ 

1E RNG‏ : تدل أن المجموعة في حالة تنظيف لبياناتها بعدما طلب ال 084 ذلك بواسطة 
جملة ال 5Q1.‏ التي تطرقنا لها قبل قليل وبعد ان تنظف المجموعة تتحول الحالة الى (٤Sا0N)ل.‏ 
6EBA RING_ CURRENT‏ :دل أن المجموعة تم تنظيفها بعد طلب جملة ال اQ؟.‏ 
:[NAC"1۷٤‏ تدل على أن أل/مء4 هه( ليس بحاجة الى المجموعة ولا تلزم في عملية ال 
Recovery‏ » وهذا هو النوع الذي (يمكن حذف. 


:VSLOGFILE 


تحتوى على بيانات حول أعضاء المجموعات. يوجد 4 حالات يكن*أن يتواجد فيها العضو وهم: 


0 !۲ تدل على أن ملف العضو لا يعمل. 

:S1۸ 1٤‏ تدل على أن بيانات العضو غير مكتملة. 
PEL 50‏ : تدل على أن العضو لا يستخدم. 
فارغ ")م و[8": تدل على أن العضو يتم استخدامه. 


مثال تطبيقي 4.8: 


SELECT GROUP# , SEQUENCE#, BYTES, MEMBERS, STATUS 
FROM V$LOG; 


SELECT GROUP#F, STATUS, TYPE, MEMBER FROM V$ŞLOGFILE; 
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ARCHIVED LOG FILES 


من أهم الأمور التي يجب تحديدها من قبل ال 084 هو قرار وضع ال مءوطه٤a(‏ في وضعية ال 
 rchivelog‏ أو .Noarchivelog‏ توجد ال وواه في الحالة الأفتراضية u)"‏ هfم5"‏ في وضعية 
ال ogاNoarchive‏ ولكن وضعية ال عه 1ء1۷ طء۸۲ مفيدة جداً حيث أن من فوائدها تسهيل عملية ال 
Backup‏ وتضمن استعادة "رإء "R٥٠۷‏ البيانات التي حدث لها اندصمصه). يمكن أن تتم عملية ال 
Archive‏ لملفات ال ع0 ل٠8‏ بطريقتيين هما: يدوية أو أوتوماتيكية والذي يتحكم بها عامل من عوامل 
.LOG_ARCHIVE_START 4% Intialazation Parameter File Û‏ 

عندما تکون قيمة ال 106G  ARCHIVE_ST ART‏ تساوي eںu٣۲‏ فان عملیة ال عہاہاط٤۸۲‏ تحدث 
بشكل آتوتوماتيكي للمجموعة الممتلئة بواسطة ال م٣۸۸‏ بعد حدوث عملية ._0g Swi‏ 

أما عندما تون قيمة ال 1_106 ۸R‏ ۷E_S1آRCH‏ ۸ تساوي Fa1[se‏ « فن عılnة Archiving ÛJI‏ 
يجب أن تحدث بطريقة يدوية عبر استخدام جمل ال اSQ.‏ 


یتم تخزین بیانات في ال ۴٥‏ 1٥٤رہ‏ اذا تمت عملیة ال عماہاط٤ ۸٣‏ بنجاح. 
يمكن القيام بعملıة Mı u[tip]ex‏ لملفات „Archived Redo Log ÛJI‏ 
لايمكن لل ۽0 Archived Redo‏ أن تتبع نظام ال .OMF‏ 


تذکر: لا یمکن استخدام ال ٥ذ۴‏ ۽0 R46‏ "حتی تتم عملي Archiving ةıذlع pتıs Checkpoint Û|‏ 
للملف (هذه الحالة تحدث عندما یکون الو :٥1ع‏ 11۷ء۸۲ › إما عند حالة عم[م۷زطءإوهN‏ فقط عملية ال 
Checkpoint‏ یجلب ان تحدث). 


:QUERYING ARCHIVED REDO LOG 
.Console JI ja gi VŞINSTANCE ja Archiving JI ةılnع يمكن الحصول على بيانات حول‎ 
:4.9 مثال تطبيقي‎ 
SELECT ARCHIVER FROM VSINSTANCE; 
أو عبر ال م1موه ه٥ باتباع الخطوات التالية:‎ 
.Standalone ادخل الى ال s01¢ئCon عبر‎ 
لکي تظهر نافذة تطلب من اسم المستخدم و كلمة السسر.‎ Database Û اضغط على اسم‎ 
..٠هإ أدخل اسم المستخدم و كلمة السر مع التاكد من اختيار $۷584 عوضاً عن إو‎ 


اضغط على .Configuration JآذزJۓغ bخض| pû « Instance Manager Û|‏ 
اضغط على کلمة ال ر0۷6-R۸e.‏ 
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آل ہےل۔ الاس 
ملفات الداتا والتببل سبيس 


DATA FILES & TABLESPACES 


TABLESPACE 


كما عرفنا سابقاً أن ال مووطه)هD‏ تنقسم الى اوذعم_ و اهزور ط۴ بحيث تكون ال #»ومءء1طه1 هي 
أحدی مکونات ال [ھc‏ زع 0[ بالإضافة الى .Data Blocks Extents ys Segment‏ ل یمکن لل 
espaceاbه"‏ العمل لأكثر من مووط هه( واحدة ولكن بالمقابل يمكن لل مء دمءء1طه٠‏ أن تحتوي على 
أکثر من ۴1٥‏ a٤ے(.‏ 

یوجد نوعان من آنواع ال ۲ 2م؛1 ط۲۵ هما: 


:SYSEM TABLESPACE‏ هي ال aceمpءءاطاه۲‏ التي تتكون مباشرة مع تكوين ال 
Database‏ لأنها ضرورية لعمل ال مووطو٤ه0‏ ولا يمكن لل مووطو)ه0 العمل بدونها. تحتوي 
على بیانات ال رھ ەi)ء¡D Daa‏ وبرامچ ال P/Q)‏ مثل یانما 0۲۵۵)؟. تحتوي ایضاً 
عٺى ال SYSTEM UNDO SEGMENT‏ ويمكن أن تحتوي على البيانات "4)4" ولکن لا 
يفضل جمع البيانات في ال ٥2م‏ ٥1ا۲۸‏ ”ء)ءر؟ بل في النوع الثاني من ال ce‏ 4مء٥1ط۾٣آ.‏ 


:NON-SYSTEM TABLESPACE‏ لإضافة مرونة على التحكم بال مووطو٤ه‏ › ينصح 
باضافة ومع ومءع[ط ه٠‏ الى ال مووطه)ه لتخزين البيانات على مختلف أنواعها. من فواند 
استعمالھا انها تقوم بفصل Application ùe < Temporary Data ùjع «< Undo Data‏ 
هط أي أنها تفصل البيانات على حسب أختلافها » ومن فوائد استعمالها ايضاً أن ال 58۸ 
يستطيع التحكم بحجم المساحة الممنوحة لكل مستخدم في ال مووطواة0. 


:CREATING TABLESPACES 
يمكن تكوين ء٥ مء 1طه٠ باستخدام القاعدة التالية:‎ 
CREATE TABLESPACE tablesBace's name 
[DATAFILE C1] 
[MINIMUM EXTENT numberA{K | M]] 
[BLOCKSIZE number [K] |] 
[LOGGING | NOLOGGING] 
[DEFAULT C2] 
[ONLINE | OFFLINE] 
[PERMANENT | TEMPORARY] 
.50ءfهںuا) ملاحظة: الكلمات التي تحتها خط في القاعدة هي ال‎ 
فترمز الى جزء من القاعدة تم تخفيفه الى رموز لسهولة قراءة القاعدة:‎ ٥2 C1 أما ال الرموز ال‎ 
'filename' [SIZE number [K | M] [REUSE] | REUSE] [AUTOEXTEND ...] =C1 


STORAGE (INITIAL number K|IM NEXT number K|M =C2 
MINEXTENTS number PCTINCREASE number MAXEXTENTS number) 


سوف يأتي شرح بالتفصيل لعوامل ال €2 المبينة )... Mnifial, Nexk‏ و جaل .AUTOEXTEND Ji‏ 
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أما أوامر القاعدة فهي : 


:][MINI]MUM EXTENT]‏ تحدد حجم جمیع ال وہم٤×E‏ الذین ینتمون الی ال 
مeوspعاطه"‏ بحيث يكون الحجم مضاعفات الرقم الموجود بجانب الجملةء يعني اذا كان الرقم هو 4 
فيكون أحجام ال و)) ×۳ مضاعفات هذا الرقم (...,16 ,8 ,4). 

DB_BLOCK _S17ZE Jalعdا لى‎ اikرعت‎ B1ock Size J| حجم‎ دıدحتل‎ :]BLOCKSIZE] 
ولكن يسمح الأوراكل بوجود أربعة أحجام أخرى لل‎ S١02١ والذي يحدد الحجم المسمى بال‎ 
في حالة أن حجم ال ھل« ھt؟ لا یناسب ال‎ Non -Stan تسمى ل ھل‎ Block Sie 
N0 - وعندئذ يمكن تحديد ال م1؟ )ء810 بواسطة هذه الجملة ويكون حجم ال‎ "a bاespa‎ ce 
.32 K8 بین 28 الى‎ Standard 

:]][0GGING]‏ تحدد أن جمیع عناصر ال ceےمء1eط‏ ھ٦‏ من sم1ط ٣a‏ و dexesہ1‏ وغیرھا 
يجب أن يتم كتابة المتغيرات التي تطراً علیها الى ال esا¡۴ .Redo Log‏ 

:][NOLOGGING] °‏ تحدد أن جميع عناصر Indexes yg Tables ja Tabl1espace ÛI‏ 
وغيرها يجب أن لا يتم كتابة المتغيرات التي تطرأً عليها اڵ .Redo Log Files J|‏ 

"Storage Parameters" jيjتلا تحدد عوامل خاصة تسمى عوامل‎ :][(E۴AULT ٥C2] 
التي سوف نتطرق لها لاحقاً.‎ 

:]0۴۴L1NE]‏ یوجد عدد من الحالات التي یمکن أن تکون علیھا ال ۲م٥1‏ ط٣۲‏ بعد تكوينها 

والحالة تحدد أنها غير جاهزة للاستخدام (ضد ممنام0). 

:]PERMANENT1|‏ تحدد أن نوعية ال ءءومءم1ط ه1 من النوع الذي يحمل بيانات دائمة. 

:]۲"EMPORARY]‏ تحدد أن آيوعية ال ء»ومءء[اطه1 من النوع الذي يحمل بيانات مؤقته. 


مثال تطبيقي 5.1: 
لتكوين ال عع دمءء1ط ه1 باستخدام جملة ال 5Q1‏ يمكح كتابة: 


CREATE TABLESPACE user dat 

DATAFILE '...l\oradata\db01\usêrdata01.dbf' SIZE 50M 
AUTOEXTEND ON NEXT 5SMZMAXSIZE 100M 

LOGGING 

OFFLINE 

TEMPORARY 

DEFAULT STORAGE (INITIAL 1M NEXT 1M MINEXTENTS 2 
PCTINCREASE 0 MAXEXTENTS 

999) 
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أو عبر ال م1موه ه٥‏ باتباع الخطوات التالية: 


ادخل الى ال s01¢ئCon‏ عڊر .Standalone‏ 

اضغط على اسم Database Û‏ لکي تظهر نافذة تطلب من اسم المستخدم و كلمة السر. 

أدخل اسم المستخدم و كلمة السر مع التاكد من اختيار $S¥۷5S5(84‏ عوضاً عن إورإه". 

.Storage Manager J| اضغط على‎ 

اضغط على عءومءء1طه٠‏ ثم بواسطة الضغط بالزر اليمين للفأرة على ال عءےمء٥1ط ٠٣‏ تظهر 
آوامر › اختر ٥4٤٥‏ ). 

ه تظهر نافذة جديدة › ادخل البيانات المطلوبة مثل اسم ال ٥٥ے‏ م٤٥‏ 1ط ۲۸ وال ۴1٥‏ و)D4‏ التابعين 
لل 2e‏ مء 1ط ۲4 وباقي البیانات « pû‏ !ضخغط .CREATE‏ 
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MANAGING TABLESPACES SPACE 


عندما يتم تخصيص مساحة لأي عنصر داخل ال ٥٥ےمءع1ط‏ ۲4 يكون لكل عنصر ۲”٥عع5‏ تحوي على 
مجموعة من ال و٤"‏ )×5 ويمكن ادارة مساحة ال 5×٤‏ بطريفتين هما: 
Dictionary Managed Tablespaces Locally Managed Tablespace‏ 


ملاحظة: لا يمكن تغيير طريقة إدارة ال و)٥)×>E‏ بعد تحديدها. 


:LOCALLY MANAGED TABLESPACE 
تتبع ال ٥ءدمءء1ط14 هذه الطريقة عندما يتم تخزين معلومات ال و)٥)×E في ال وم[ذ۴ وه التابعة لل‎ 
۴e۵ 810 ks يتم تخزین البيانات على شكل مه.)81 (خريطة بایتات) والتي تدل علی ال‎ . "bp 
وعندا يحدث أي تعدیل على ال ءء810 يقوم الأوراكل بتجديد بيانات‎ ۰5×٥٤ و ال sءkء10اB 4ا في ال‎ 

المو_ا81 لتوافق التغيرات التي طرأت. 
من فواند استخدام طريقة ال e‏ ي4ى Na‏ yااcaء0[:‏ 
تخفف الضغط على ال راو 5¡):6 .0a)4‏ 
حجم ال 5×٥٤‏ يمكن أن يقدر بشگل أوتوماتيكي و جمیع ال E×)٤s‏ تكون بنفس الحجم. 
ه عدم الحاجة الى جمع المساحات الخالية الصغيراة الضائعة التي تنشئ بين البيانات نتيجة للتغيرات 


التي تحدث وتعيد ها الى المساحة الخالية الرئيسية,وتسمى هذه العملية Coalescing Space‏ 
( بمعنى أخر أنها تمنع حدوث عمليات عديدة تسبباضغط على ال مووطو)ة0). 


لتكوين وءءدمءع1طه٢‏ تتبع هذه الطريقة »> يجب اضافة الجملةءالتالية الى قاعدة 
:CREATE TABLESPACE‏ 


EXTENT MANAGEMENT LOCAL 
[AUTOALLOCATE | UNIFORM [SIZE number [K|M] ] ] 


نقاط مهمة: 
1- لا يمكن استخدام جملة ال [DEFAULT C2]‏ 
2- لا يمکن استخدام كلم .TEMPORARY J|‏ 
3 لا يمکن استخدام جمل .MINIMUM EXTENT JÛ‏ 
أما أوامر الجملة فهي : 
U10 L0 TE‏ : یقوم الأوراکل بتحدید حجم ال )× ولا یستطیع ال8۸( فعل ذلك. 


UNIFORM °‏ : یتم تحدید حجم ال Ex)‏ من قبل ال 58۸. 
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مثال تطبيقي 5.2 
يمكن تكوين ءءهمءم1ط ه۲ تتبع طريقة ال كمعد" راآاهء0[ بكتابة التالي: 
CREATE TABLESPACE app_data‏ 


DATAFILE '...loradata\db01\appdata01.dbf' SIZE 250M 
EXTENT MANAGEMENT LOCAL UNIFORM SIZE 256K; 


أو اذا تم كتابة التالي فقط › فتعتبر ca11y M4" 2g‏ 10 ویؤخذ :Autoallocate yy Default Û|‏ 


CREATE TABLESPACE app_data 
DATAFILE '...\oradata\db01\appdata01.dbf' SIZE 250M; 


:DICTIONARY MANAGED TABLESPACE 


تتبع ال ءءدمء٥1طه٣‏ هذه الطريقة عندما/يتم تخزين معلومات ال sئExten‏ في .Data Dictionary ÛJI‏ 
من فوائد استخدام طريقة ال ٥d‏ عد رة رة« هذا انها توفر مرونة في تحدید حجم کل ”۸٥۲‏ ع٥5‏ على 
حده باستخدام جملة ال ٤2[‏ 11 0 ۴۸[ .لكن في المقابل تلزم الحاجة الى جمع المساحات الخالية 
الصغيرة الضائعة التي تنشئ بين البيانات نتيج للتغيرات التي تحدث و تعيدها الى المساحة الخالية الرئيسية › 
أي حدوث عمليات قد تسبب مزيد من الضغط على ال6ءوطه)ة5. 


لتكوين وءءدمءع1طه٢‏ تتبع هذه الطريقة »> يجب اضافةرالجملة التالية الى قاعدة 
:CREATE TABLESPACE‏ 


EXTENT MANAGEMENT DICTIONARY [DEFAULT C2] 
:5.3 مثال تطبيقي‎ 
CREATE TABLESPACE app_data 
DATAFILE '...loradata\db01\appdata01.dbf' SIZE 250M 


EXTENT MANAGEMENT DICTIONARY 
DEFAULT STORAGE (INITIAL 1M NEXT 1M]; 


MINIMUM J أو جملة‎ [D٤۴۸ ملاحظة: يمكن تغيير قيم العوامل ضمن الجملة [°2 011ا‎ 
.Console JI oe yİ « ALTER TABLESPACE رمڼJا‎ مIlدخîwlڊ‎ EXTENT 
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مثال تطبيقي 5.4: 
لتغيير جم :Minimum Extent J|‏ 


ALTER TABLESPACE app_data MINIMUM EXTENT 2M; 


:Default Storage... J| لتغيير جمل‎ 


ALTER TABLESPACE user_data 
DEFAULT STORAGE ( 
INITIAL 2M 
NEXT 2M 
MINEXTENTS 1500); 


أو عبر ال م1امء"”ه٥‏ باتباع الخطوات التالية: 


ادخل الى ال Co nso‏ عڊر .Standalone‏ 

اضغط على اسم Database Û‏ لکي تظهر نافذة تطلب من اسم المستخدم و كلمة السر. 

أدخل اسم المستخدم و كلمةالسر معب التاكد من اختيار S۷5584۸4‏ عوضاً عن إورإه". 
اضغط على .Storage Manager J|‏ 

اضغط على ٥ء4‏ مء٥1ط‏ ه٠‏ ثم الضغظ بالزر اليمين للفأرة على اسم ال مء دمء٥1[طھ۲‏ المراد تغير 
خواصها لتظهر قائمة أوامر» أختر من الأىامر .View\Edit Details‏ 

٠ه‏ تظهر نافذة جديدة › اضغط على كلمة معدم ثم أدخل التغيرات المطلوبةء ثم اضغط رام م۸. 


تذکر: أنه لا یمکن تغییر خواص ال ٥ع۲4٥)؟‏ لل ٥ھ‏ مم1 ط۸٢‏ التي تتبع طريقة ال لء2g M4”‏ yاا0caا.‏ 
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NON-SYSTEM TABLESPACES 


يوجد أكثر من كم دمءءاطه٣‏ «mءاءرS-«هN‏ ولكل منها وظائف مختلفة في ال مووطه)ه › منها 
.Temporary Tablespace s Undo Tablespace y Permanent Tablespace‏ 

أما Permanent r ablesp ace‏ فوظائفها تخزین البيانات ") 51" لفصل بیانات ال eءھ‏ 4٤ھ‏ عن 
بيانات ال راه« ٠ء1‏ واه( و لسهولة التحكم في البيانات بحيث اذا تم حذف ال مءومءم1ط 14 الخاص 
بها لا يؤثر ذلك علی عمل ال رہ)1 و( و لتخفیف الضغط علی ال ceے System ٣1٥p‏ وال 
atabAseط‏ بشكل عام. 


:UNDO TABLESPACE 


تستخدم لحفظ ال ۲٠ص‏ عهS‏ 0ل 11ا ولا يمكن أن تحتوي على غيرها. يتم إدارة ال و٤ه)×5‏ بطريقة ال 
Managed‏ yاا0ca.ا‏ و يمكن تكوينها باتباع القاعدة التاليه (أو تكوينها عند تكوين ال #ءsوطه)ة5‏ 
ڊlتخد|م :(CREATE DATABASE‏ 


CREATE UNDO TABLESPACE tablespace name 
[DATAFILE C1] 

EXTENT MANAGEMENT LOCAL 

[AUTOALLOCATE | UNIFORM [SIZE number{K|M] ] ] 


ملاحظة: تستخدم Undo Tablespace Jl‏ في ال ئ ۸ıt0omatic Undo Managenîen‏ التي سوف 
نتطرق لها في فصل أخر مع ال ۲ Seg‏ d0ہ0ا.‏ 


مثال تطبيقي 5.5: 


CREATEUNDO TABLESPACE undo01 
DATAFILE '...\oradata\db01\undo101.dbf' SIZE 50M; 


أو عبر ال م1مء ه٥‏ باتباع الخطوات التالية: 


ادخل الى ال Console‏ عڊر .Standalone‏ 

اضغط على اسم ال مووطه)ه لكي تظهر نافذة تطلب من اسم المستخدم و كلمة السر. 

أدخل اسم المستخدم وكلمة السر مع التاكد من اختيار S۷¥5S584‏ عوضاً عن إومإه.. 

.Storage Manager Û JJع |ضخط‎ 

اضغط علی ٥٥ے‏ موم1ط ه۲ ثم الضغط بالزر الیمین للفأرة علی اسم ال c۲‏ 2م5٥‏ 1ط ٣۹‏ المراد تغير 
خواصها لتظهر قائمة أوامر» أختر من الأوامر مtو٠إ).‏ 

٠‏ تظهر نافذة جديدة » أختر ملم ا عوضÎ‏ عjù Permanent‏ ثم ادخل البيانات المطلوبة مثل اسم ال 
pî Tablespace‏ ضط .Create‏ 


JI و‎ Alert Log File JI g Control File J| تخزن في‎ €n d0 Seg men † تذکر: بیانات ال‎ 
.Initialization Parameter File 
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:TEMPORARY TABLESPACE 


توفر المساحة اللازمة لعمليات ال 50٤‏ المختلفة الناتجة عن أوامرعدة مثل ر8 .Group Byوأ 0dr‏ 
بمعنى أخر أنها تخزن البيانات المؤقتة 4)a"‏ 0 ھا0 م ص٥۲"‏ وتحوي ما یعرف ڊ Sort Segment‏ 
والتي تتكون في ال ٥٥م‏ ء٥1‏ ط۲1 عند أول عملية $0۲ تطلب من ال ce‏ ھtءہ[.‏ یمكن إدارة ال و٤ Ex)٤‏ 
بالطريقتين و لکن ينصح باستخدام ._0c211y M4 "4g‏ 


ملاحظة: تستطيع ال ٠٠۲‏ عءم$ 50۲۲ التوسع في المساحة بحجز المزيد من ال E×)٥"٤s‏ لكي يتم تغطية 
المساحة اللازمة لعمليات ال 50۲ المختلفة. 


يمکن تکوين CREATE TABLESP ACE ةlaج pIدختlب Temporary Ta ۆb1espace Û|‏ مع إضافة 
كلمة "EM P0٥١ R ۸R‏ في الجملة و لكن يفضل استخدام القاعدة التالية لتكوين e‏ ع4 Ma"‏ yاا0ca[:‏ 


CREATE TEMPORARY TABLESPACE temp's name 
TEMPFILE 'filename' 

EXTENT MANAGEMENT LOCAL 

[AUTOALLOCATE | UNIFORM [SIZE number [K|M] ] | 


مثال تطبيقي 5.6: 


CREATE TEMPORARY TABLESPACE temp01 
TEMPFILE '...\oradata\db05\tenîpO01.dbf ' SIZE 200M 
EXTENT MANAGEMENT LOCAT UNIFORM SIZE 10M; 


أو عبر ال م1مو ه٥‏ باتباع الخطوات التالية: 


ادخل الى ال Console‏ عڊر .Standalone‏ 

اضغط على اسم Database Û‏ لکي تظهر نافذة تطلب من اسم المستخدم و كلمة السر. 

أدخل اسم المستخدم وكلمة السر مع التاكد من اختيار Ş584؟S۷‏ عوضاً عن إوصرإه.. 

.Storage Manager J| اضغط عل‎ 

اضغط على ٥٥‏ 4مءع1ط ه٢‏ ثم بواسطة الضغط بالزر اليمين للفأرة على ال ٣4 ط1٥ءمے ce‏ تظهر 

آوامر › اختر .٤°٥4)٥‏ 

٠‏ تظهر نافذة جديدة › أختر الخیار رإ مم٥۲‏ عوضاً عن ٤٤م‏ ھ ۴٥٣.‏ ثم ادخل البیانات 
المطلوبة مثل اسم ال ءءومءء1طه١‏ و أدخل البيانات التابعة لقسم ال معوإه)S‏ مثل ال مذS.‏ 

ثم أضغط م٤وءإ)٤.‏ 


يعتبر "EMPFILE‏ (الذي استخدم في القاعدة) متطابقاً لل ٤۳۴ا A۴]‏ عدا في الاختلافات التالية: 


لا يمكن وضعه في حالة القراءة فقط yرار0-4dءR۸.‏ 

لا يمكن تغيير اسم الملف. 

لا یمکن أن یتم له عملیة رم۰0۷ .R۸‏ 

لا يمکن تكوين4 بlستخدIم .ALTER DATABASE ÛJI‏ 
دائماً في وضعية اJ .NOLO0OGGING‏ 

.CREATE CONTROLFILE JI ةlaج‎ g لا يمکن استخدامھا‎ 
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:Default Temporary Tablespaces 


بlتخدIم‏ قlعدö hefault Temporary Tablespace jıgكت jas CREATE DATABASE‏ والتي 
تحمي ال میوط هه( من استخدام ال 2e‏ مء٥1ط‏ ھ۲ System‏ عوضاً عن ال ر۲ه۲هم ۲٥"‏ في تنفیذ 
عمليات ال 50٤s‏ والتي قد تؤدي الى مشاكل عدة في ال مءومءء[طه1 "٠٤ءر؟‏ وازدياد نسبة ال 
.System Tablespace Û Jl Fragmentation‏ 

في حال لم یتم تکوین ال ce‏ 2 م ary ٦2ا1 es‏ emporآ‏ مع تکوین ال 46 ط4)4 0 وتم تکوینها بعد ذلك › 
يمکن تحدید Default Temporary Û li‏ بواسطة مر ALTER DATABASE‏ وجمیع 

المستخدمین الذین کانوا یستخدمون ال ce‏ ےم ٥e٣ ۲۸1٥٤‏ )ءر؟ لعملیات ال 80٤۶‏ یتم تحویلھم بشكل 
أوتوماتيكي ا .Default Temporary Tabl1espace Û|‏ 


ملاحظة: اذا اراد DBA J|‏ تير Temporary gl Default Temporary Taۆb1espace JI‏ 
ce‏ espaاb‏ هآ اخرى لتکون هي ال )ا ھfء5‏ « يمکن استخدIام .ALTER DATABASE‏ 


CREATE 4طwlgڊ‎ Default Temporary Taۆb1espace‎ Û| ùيyكت ملاحظة2: اذا تم‎ 
.L0ca211y M4 4g e فإنھا تتبع طریقة ال‎ D1 ۸ BASE 


:Default Temporary Tablespace قیود ال‎ 


Temporary yl llgحت عد‎ ¥! Default Temporary4Eab1espace J| لا يمكن حذف‎ 
.ALTER D۸T۸AB4ASE'IlAطwسlgڊ‎ aڙخأ‎ Tablespace 


.Permanent yil Defaîlt Temporary Û Jيوحت لا يمکن‎ 


ه لا يمكن وضعها في حالة ال ممذا؟؟0. 


مثال تطبيقي 5.7: 


لتعریف ال ceھم1espط‏ ھ٣ rem porary‏ کنوعیة ال ٤اuھfمD‏ أو لتغییر ال Default ۲e poy‏ الی 
آخری يجب كتابة التالي: 


ALTER DATABASE DEFAULT TEMPORARY TABLESPACE temp02; 
أو عبر ال م1مء"٠C باتباع الخطوات التالية:‎ 


ادخل الى اÛ Console‏ عڊڙر „Standalone‏ 

اضغط على اسم ال مووطه)ه( لكي تظهر نافذة تطلب من اسم المستخدم و كلمة السر. 

أدخل اسم المستخدم وكلمة السر مع التاكد من اختيار S۷¥5S584‏ عوضاً عن إوصإه.. 

.Storage Manager J| اضخط ع‎ 

اضغط على عءومء٥1طه٠‏ ثم بواسطة الضغط بالزر اليمين للفأرة على ال ع ےمء٥1ط ٠٣‏ تظهر 

آوامر › اختر ع٥)4٥۲).‏ 

٠‏ تظهر نافذة جديدة › أختر الخیار رإھإم م٥۲‏ عوضاً عن )٤مھ‏ ص٣٥۴‏ ثم ادخل البیانات 
المطلوبة مثل اسم ال ءءومءم1ط ه٠‏ وأدخل البيانات التابعة لقسم ال معوإهمSt‏ مثل ال م1z؟.‏ 

.Create ضط‎ pî Set as Default Temporary Tablespace ةilخlا يجت تحږديد‎ ٠ 
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ALTERING A TABLESPACE 


یمکن تعدیل 6۶ے مءع1ط ۲۸ أو حذفهم بواسطة أمر ۸L۲ ER "A BLESPACE‏ بحیث یمکن تنفیذ 
بواسطة هذا الأمر: تغيير الحالة بين ممذا؟؟0 و ٭ء«نام0 › وضع ال مءومءء1ط ه٣‏ في وضعية القراءة فقط 
Read-Only‏ › حذف aceمspم1‏ اھ۲ › تغییر حجم ال 2٥e‏ م؛٥1ط‏ ۰۲۹ وغیرها من المهام. 


:OFFLINE OR ONLINE 


عندما تکون ال Tablespace‏ في حالة Y' «Offline‏ يستطیع المستخدم استخراج البيانات المخزنة في ال 
Tablespace‏ من ال e‏ طata(.‏ یمکن وضع ال ceےمb1e ۲a‏ في حالة ال مءمذا؟؟0 لعدة اسباب منها أن 
ال D8۸‏ يرغب في اغلاق جزء من البيانات أو عمل عملية up‏ )ه8 أو رإء۷٠ء٠8‏ على هذا الجزء دون 
اغلاق ال موه طه)هD‏ بشکل تام أو نقل أو تغییر اسم ی٥۴1 4٤a‏ لل ceےمءم1ط‏ ھ۲ دون إغلاق ال 
8t4‏ بشکل کامل. 

عندما تتغير حالة ال #عومءء1طه١‏ من ء«نام0 الى م«ذا؟؟0 أو بالعكس» يتم تخزين معلومات حول العملية 
في Tablespace JI ةll Jugحت [stance Jl jn .Contro1 File J| „ês Data Dictionary Û|‏ 
بين الحالتين عند حدوث أخطاء أو مشاكل مثل عدم المقدرة على نقل البيانات الى ال مومءءاطه1. 

لا يمكن وضع جميع ال وء مء٥1ط‏ ه۲ في/حالة ال neم1i؟؟0‏ اذ يسثنى کل من System Taۆ1espace Û‏ 
Default Temporary Û‏ وال ê¢espaاb ra‏ التي تحوي Undo Segment‏ في حال .Active‏ 


يمكن التحويل بين الحالتين باستخدام القاعدة لتالية: 


ALTER TABLESPACE tablespace's nãme 
ONLINE | 
OFFLINE [NORMAL | TEMPORARY | IMMEDIATE| FOR RECOVER] 


أوامر القاعدة: 


Data Files JIب الخاصة‎ "Dirty Bu ffمrء'" يتم كتابة جميع البيانات المتغيرة‎ : NORMAL 
ضمن ال 4م٥1 ط۲۸ المراد إغلاقها.‎ 5٤4 ۴16s في ذاکرة ال 96۸ الی ال‎ 
ضمن ال‎ 0nاine‎ Data ۴ ¡1es لجمیع ال‎ Check poi توفر عملیة‎ : TEMPORARY 
.Offline Data Files JÛ المراد إغلاقها و لا توفر ذات العملية‎ ra bاespace‎ 
Tablespace JI jaضځ‎ Data Files JI ıJ Checkpoint لا تقوم بعملية‎ :]MMEDIATE 
.0واiمم المراد غلقها وبالتالي يجب القيام بعملية رإ ء0۷٠٠۸ عند الرغبة بتحويلها الى‎ 
.Rec0very ا۲4 في عملیة‎ 1esp2 ce لاستخدام ال‎ :FOR RECOVER 


تذکر النقاط التالية: 


Temporary JÎ Permanent Taۆ1espace‎ J| يعمل عندما يتم وضع‎ DBW n أن اڵ‎ 
.Offline ÛJI lla „ê Tablespace 


ه٠‏ أن وضع ال ءءدمءء[ط ه١‏ في حالة ال ادإ ء«نا؟؟0 يؤدي الى حدوث عملية ال 
.Checkpoint‏ 


ه أنه يمكن وضع ال 4# مءء1طه٣‏ في احدى الحالتين عند تكgيli‏ بوlسطة CREATE‏ 
.TABLESPACE‏ 
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مثال تطبيقي 5.8: 
وضع ال #ء4مءء1طه۲ في حالة ال م«ذام0 يجب كتابة: 


ALTER TABLESPACE user_data ONLINE; 


لوضع ال #ءومءء1طه۲ في حالة ال ٠«ذا؟؟0‏ يمكن كتابة: 
ALTER TABLESPACE user_data OFFLINE;‏ 
ALTER TABLESPACE user_data OFFLINE IMMEDIATE;‏ 


ALTER TABLESPACE user_data OFFLINE TEMPORARY; 


أو عبر ال م1مء"”ه٥‏ باتباع الخطوات التالية: 


ادخل الى ال ٣٥٥01‏ عبر .Standalone‏ 

اضغط على اسم ال ماه( لكي تظهر نافذة تطلب من اسم المستخدم و كلمة السر. 

أدخل اسم المستخدم وكلمة السر معآالتاكد من اختيار S۷584‏ عوضاً عن إوصإه.. 
اضغط على .Storage Manager J|‏ 

اضغط على ال + بجانب كلمة ءءومم1طه1 ليظهر قائمة بأسماء ال ومومءاطه1. 

اضغط علی اسم ال ٥6‏ 2م٥1‏ ط ه۲ المرادتحويل حالتها. 

يظهر على النافذة الیمنی بعض خصائص ال م26مء1ط ٠١٠‏ اختر م,ذا؟؟0 وحالة الإغلاق من 
المجموعة التي بجانبها ثم اضغط على رام م ۸؛ 


:READ-ONLY TABLESPACE 


يمكن وضع ال عءومءء[ط ه1 في حالة القراءة فقط "رام "۸8٥43-0‏ اذا رغب ال D8۸‏ بأن تتم قراءة 
بیانات ال وم۴1 )04 ضمن ال ٥ے‏ مء٥1ط‏ ۲۹ دون تغییر البیانات. لکي یستطیع ال 8۸4( وضع ال 
espaceاb ra‏ في حالة ال رارRe4۵-0‏ یجب أن یکون جمیع ال ۴1٥s‏ واھ( التابعیین لل ceےb1epھ۲آ‏ 
في وضعية ما0 وإلا فأن العملية لن تنجح › والعكس صحيح في حال تحويل ال #ءومءء1اطه1 من 
yا0n-ل Rea‏ الى الحالة العادية Wr¡†e-44ءRe‏ يحب توفر جميع ال و۴116 )04 في وضعية eمiام0.‏ 
يمكن وضع ال #ءدمءء1[طه١‏ في حالة رام4-0 ه٠8‏ باستخدام القاعدة التالية: 


ALTER TABLESPACE tablespace's name READ [ONLY | WRITE] 
اذ أن حذف عناصر لا تکون‎ Read-Only ab espace من ال‎ )٣ھ‎ 1es, يمکن حذف عناصر (ءع×eع ل1۸‎ 
.04)a (ان٠ بيانات جديدة في ال مء ومءه[ط ه۲ ولا تغيير البيانات الموجودة إنما تغيير بيانات ال رإو‎ 
وفي حال كانت تجرى على ال عcومء٥[طه1 عدد من المهام "٠0إاءدورهإآ" عند عملية التحويل › يتم‎ 
منع حدوث مهام جديدة ويتم انجاز المهام التي تجري وإما أن تسجل البيانات الناتجة عن المهام عند حدوث‎ 
.R‌ها11!ط4) أو تلغی عند حدوث‎ Commit 


ملاحظة: لا يمكن وضع ال 4# م؛٥1ط۲4‏ صmءtءرS‏ في حالة ال .Read-Only‏ 
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مثال تطبيقي 5.9: 
لوضع ال ء4مءء1ط4٣‏ في حالة ال رام434-0٠8R‏ يجب كتابة: 

ALTER TABLESPACE user_data READ ONLY; 
لوضع ال عمءهمءء[طه1 في الحالة العادية:‎ 

ALTER TABLESPACE user data READ WRITE; 
أو عبر ال #امودهC باتباع الخطوات التالية:‎ 


ادخل الى ال „Standalone رjڊع Console‏ 

اضغط على اسم ال مووطه)ه لكي تظهر نافذة تطلب من اسم المستخدم و كلمة السر. 

أدخل اسم المستخدم وكلمة السر مع التاكد من اختيار S¥9S584‏ عوضاً عن إومإه.. 
اضخط ع .Storage Manager J|‏ 

اضغط على ال + بجانب كلمة مءومءء[طه1 ليظهر قائمة بأسماء ال ومومءءاطه1. 

اضغط على اسم ال c٥‏ 2م٥1‏ ط۸٠‏ المراد تحويل حالتها. 

يظهر على النافذة اليمنى بعض خصائص ال مء دمءء1طاه1» ضع علامة في المربع بجانب كلمة 
Read Only‏ » تم اضغط على رام .A‏ 


تذكر: أن وضع ال مءومءم1ط ه٠‏ في حالة ال ”را آً4-0هءR‏ يؤدي الى عمل ال (8W‏ و حدوث عملية ال 
.Checkpoint‏ 


:DROPPING TABLESPACES 
يمكن حذف ء4مءء1طه٣ من ال 44#طه)ه0 باستخدام القاعدة التالية:‎ 


DROP TABLESPACE tablespace's name 
[INCLUDING CONTENTS [AND DATAFILES] [CASCADE CONSTRAINTS]] 


أوامر القاعدة: 


:I[NCLUDING CONTENTS‏ اذا كانت ال e‏ 4م1s‏ 14 خالية لا تحوي أي بيانات 
"واه" فلا يشترط كتابة هذه الجملة › ولكن اذا كانت تحوي على بيانات "و٤54"‏ فيجب كتابة 
هذه الجملة. 

AND DATAFILES °‏ : کما تعرف أن لکل ۲٥م‏ وع1ط ه۲ مجموعة من ال یذ۴ وه التابعة 
لها تكون الجزء الفيزيائي (الملفات الحقيقة) على موقع التخزين (مثل القرص الصلب). عندما لا 
تكتب هذه الجملة لا تحذف ملفات ال وا۴ ه)04 من موقع التخزين والعكس صحيح اذ أن كتابة 
هذه الجملة تؤدي الى حذف ملفات ال وم۴ و)ه( بشكل أوتوماتيكي. 

:)AS ADE CONSTRAINTS‏ يجب استخدام هذه الجملة في حالة وجود ما يعرف ب 
)F۴oreign Key) Referential Integrity‏ من ٣a 1e‏ توجد خارج ال ce‏ مspع1ط‏ ھ٣‏ المراد 
حذفھا مغ Primary Key‏ أو "abe Unique Key‏ موجودة داخل ال ce‏ 2م٥1‏ ط۲4. في حال 
وجود هذا الرابط ولم يتم استخدام هذه الجملة › تفشل عملية الحذف. 
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نقاط مهمة: 
1- یمکن حذف ال ٥‏ ھمءع1ط ه٣‏ التي توجد في وضعية رار40-0ءR۸.‏ 


2- ينصح بتحویل ال ٥۲‏ 4م٥1ط‏ ۲۵ الى حالة 1«۲ا؟0۴ قبل حذفها للتأكد من عدم وجود مهام أو عمليات _ 
تجري على ال مء ومءم1ط ه۲ » اذ بتحويلها الى ء«ذا؟؟0 يتم وقف العمليات الجديدة وإنهاء المهمات الحالية 


3- بعد حذف ال c٥‏ ےمءم1ط ھ۲ یتم تعدیل بیانات ال ۴1۲ 1٠۲٤"ه٥)‏ لتتوافق مع التغيير الذي حدث في ال 
.Tablespace‏ 


تذکر: أن ال ۴1٥‏ 1٥۲٤«ه)‏ يحوي معلومات حول أسماء ال ومءومءم1طه1 وأسماء و مواقع ال و٤54‏ 
.Files‏ 


مثال تطبيقي 5.10 
لحذف ع٥‏ ومء٥[طه‏ يمكن كتابة التالي: 


DROP TABLESPACE sêr data 
INCLUDING CONTENTS ANDDATAFILES; 


DROP TABLESPACE user _ data 
INCLUDING CONTENTS.CASCADE CONSTRAINT; 


DROP'TABLESPACE user_ data 
INCLUDING CONTENTS AND DATAFILES CASCADE CONSTRAINT; 


أو عبر ال م1مو ه٥‏ باتباع الخطوات التالية: 


ادخل الى ال .Standalone رڙڊe Console‏ 

اضغط على اسم Database Û‏ لکي تظهر نافذة تطلب من اسم المستخدم و كلمة السس. 
أدخل اسم المستخدم وكلمة السر مع التاكد من اختيار S۷5584۸4‏ عوضاً عن إوصإه.. 
اضغخط على .Storage Manager JI‏ 

اضغط على ال + بجانب كلمة مءومءع[ط ه1 ليظهر قائمة بأسماء ال ومعومءء[اطه1. 
اضغط على اسم ال 1٥۲‏ م٥1ط‏ ه۲ المراد حذفها. 

استخدم الزر اليمين للفأرة اتظهر لك قائمةء اختر 0۷eءR۸.‏ 

أختر وم۷ لتأكيد الحذف. 
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:RESIZING A TABLESPACE 


یمکن زیادة حجم ال ٥‏ ےمع[ط ۲۸ بزيادة حجم ال و۴1 وه( التابعة لها أو إضافة م۴1 و٤4(‏ جديدة لل 
ce‏ espaاab".‏ یمکن زیادة حجم ال و٥۴‏ و٤4(‏ بطريقة يدوية أو أوتوماتيكية. 


:Automatic Extension 


یمکن استخدام جملة ال ۲6۵ ٤×‏ ۸10۲0 لزيادة حجم ال و۴16 (4a‏ بطريقة أوتوماتيكية أو لوقف هذه 
العملية. يمكن استخدام جملة ال ٤×X 1END‏ ۲0 ۸€ بعد تکوين Tablespace Û! yi Database J|‏ 
باستخدام القاعدة التالية: 


ALTER DATABASE [database's name] 

DATAFILE 'filename' [SIZE number] [K | M] [REUSE] 
[AUTOEXTEND OFF|ON [NEXT number [K|M]] 
[MAXSIZE UNLIMITED | number [K |M]] 


أوامر القاعدة: 


U "0 EXTEND OFF‏ : توقف عملية زيادة حجم الملفات بشكل أوتوماتيكي. 

U7 ۲"0 EXTEND ON °‏ ۸:-لتشغيل عملية زيادة حجم الملفات بشكل أوتوماتيكي عند أمتلاء 
الملفات. 

NEX ۲‏ : حجم الزيادة عند أمتلڻا£|ل§Fi]e .Data‏ 

:M AXE‏ لتحديد الحجم الأقصىئ الذي یمکن أن یصل له حجم ال و۴1 و٤04.‏ يمكن أن يحدد 
الحد الأقصی أو ان يكون غير محدد باستخام .UN11M17 ٤‏ 


CREATE ڍ‎ CREATE DATABASE 5 في اعد‎ ۸U 10 ٤×X 1END تذكر: تستخدم جملة ال‎ 
.TABLESPACE 


مثال تطبيقي 5.11 
لزیادة حجم ال ۴16 و٤04‏ ضمن ال ٥٥2مءء1ط4٠‏ بشكل أوتوماتيكي: 


ALTER DATABASE DATAFILE '...l\loradata\db01\userdata01.dbf 
AUTOEXTEND ON NEXT 10M MAXSIZE 250M; 


أو عبر ال م1مء"”هC‏ باتباع الخطوات التالية: 


ادخل الى ال C001‏ عیر .Standalone‏ 

اضغط على اسم ال #ءطهه( لكي تظهر نافذة تطلب من اسم المستخدم و كلمة السر. 

أدخل اسم المستخدم وكلمة السر مع التاكد من اختيار 84 S۷50‏ عوضاً عن إوصإه.. 

.Storage Manager J| اضغط عل‎ 

اضغط على ال + بجانب كلمة وم۴1 ود( ليظهر قائمة بأسماء ال 6ا۴ و٤04.‏ 

اضغط علی اسم ال ۴1۲ و٤(‏ المراد تكبیرھا. 

اضغط على كلمة ال ءعوإه)؟ لتدخل الى القسم الأخر . 

ضع علامة في المربع ثم أکتب قم Unlimited laإ رتخاy « Increment (NEXT) ja J‏ او 
قیمة [ue‏ ۷ ثم اضغط على رارم ۸. 
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:Manual Extension 
يمكن زيادة أو انقاص حجم ال و٥[۴ و٤4( باستخدام القاعدة التالية:‎ 


ALTER DATABASE [database's name] DATAFILE 'filename', ['filename?2'] ... 
RESIZE number [K|M] 


سؤال: لنفرض أنه یوجد لدینا ۴|1۲ )04 حجمه M18‏ 100 وهو يحوي علی 18 70 بیانات › واراد ال 
B4‏ تصغیر حجمه الى M18‏ 60 › فهل تنجح العملية ؟ و کم یکون حجم ال ۴1۲ 04a‏ بعد التصغير؟ 


جواب: نعم تنجح عملية التصغير ولکن یکون حجم ال ۴1۲ و٤04‏ هو حجم البيانات فيه وهر M18‏ 70. 
ملاحظة: يمكن تكبير أو تصغير حجم أكثر من ملف في نفس الوقت كما في المثال 5.12 

مثال تطبيقي 5.12 

لزیادة حجم ال ی۴16 و)ے0 ضمن ال ٥٥ھ‏ مءء1ط۲4 بشکل يدوي : 


ALTER DATABASE DATAFILE '...\oradata\db01\userdata01.dbf', 
'....loradata\dbO01\userdata02.dbf’ 
RESIZE 250M; 


أو عبر ال 01ء٠٥‏ باتباع الخطوات التالية: 


ادخل الى ال „Standalone رڊۈe Console‏ 

اضغط على اسم Database Û‏ لکي تظهر نافذة تطلب من اسم المستخدم و كلمة السر. 
أدخل اسم المستخدم وكلمة السر مع التاكد من اختيار S۷958‏ عوضاً عن إوصإه.. 
اضغخط على .Storage Manager J|‏ 

اضغط علی ال + بجانب کلمة و٥۴1‏ وھ( لیظھر قائمة/بأساء ال وم۴ 04)4. 
اضغط على اسم ال ۴11۲ (4a‏ المراد تكبيرها أو تصغيرها. 

ادخل الحجم الجديد في خانة م1 ۴[٥‏ ثم اضغط رامم۸. 
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:Adding Data File 
يمكن اضافة وم۴1 و٤0 الى ال معومءء[طه"٠ لتكبير حجمها عبر القاعدة:‎ 


ALTER TABLESPACE tablespace's name ADD DATAFILE 
"filename" [SIZE number [K|M]] [REUSE] [AUTOEXTEND ...],.... 


ملاحظة: يمكن اضافة أكثر من ملف في نفس الوقت. استخدم فاصلة في أخر القاعدة وأعد كتابة السطر الثاني. 
كما في المثال 5.13. 


مثال تطبيقي 5.13: 


:Tablespace Û Jll Data Files ةİlضlل‎ 


ALTER TABLESPACE user_data ADD DATAFILE 
'...loradata\db01\userdata01.dbf' SIZE 200M 
AUTOEXTEND ON NEXT 10M MAXSIZE 250M, 
'...loradata\db01\userdata02.dbf' SIZE 200M 
AUTOEXTEND ON NEXT 10M MAXSIZE 250M; 


أو عبر ال م1مء"٠C‏ باتباع الخطوات التالية: 


ادخل الى ال €٥ 1401e‏ عبر ¢ م .Staı dao‏ 

اضغط على اسم Database Û|‏ لکي تظهر نافذة تطلب من اسم المستخدم و كلمة السر. 
أدخل اسم المستخدم وكلمة السر مع التاكد من آختيار S(584؟S۷‏ عوضاً عن إوصرإه.. 
اضغط عل .Storage Manager J|‏ 

اضغط على ال + بجانب كلمة مء وموءع[ط ه٢‏ ليظهر قانة بأسماء ال ومومءءاطه1. 
اضغط علی اسم ال c٥‏ ےمیع1ط ھ۲ المراد اضافة ١ا۴‏ واو لها. 

استخدم الزر اليمين للفأرة اتظهر لك قائمةء› ءان؟ه)0a(‏ 4لA.‏ 

تظهر لك نافذة جديدة › ادخل البيانات مثل اسم الملف ثم اضغط ع٤4٠)°.‏ 


:MOVING DATAFILES 
ALTER gyİ ALTER TABLESPACE la مIدختسlڊ ۾)54 من موقع الى خر‎ ۴1٥s یمکن نقل ال‎ 
.DATABASE 


باستخدام :Alter Tablesp ace‏ 
يمكن نقل ملفات ال ءز۴ و٤(‏ باستخدام القاعدة التالية: 
ALTER TABLESPACE tablespace's name‏ 


RENAME DATAFILE 'filename' , ['filename'] 
TO 'filename' , ['filename']; 
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ربق التق 


ضع ال ace‏ مes‏ ط4ا في .Offline ll‏ 

نسخ ملف ال ٥1ز۴‏ واه الى المواقع الجديدة (القيام بعملية النسخ كما في نظام التشغيل › اي في 
الويندوز يستخدم llفİزة „PASTE ys COPY ga‏ 

تنفيذ القاعدة السابقة. 

تحویل ال ce‏ 4 مءع1ط "a‏ الى Ûlئllة Online‏ 

يمكن حذف ال ١ء۴‏ ه)4( الموجودة في الموقع القديم كما في نظام التشغيل. 


شروط الاستخدام: 


يجب أن تكون ال #ءومءء[ط ه۲ في حالة اÛ .Offline‏ 

يجب تواجد ملفات ال وء[ذ۴ )د المراد نقلها في الموقع المحدد في القاعدة. 

يجب أن تتطابق اسماء ال و۴6 a)ه0‏ المنقولة مع اسماء ال وماز۴ وه المخزنة في ال 
.Control File‏ 

لا یمکن نقل ی٥۴1‏ وھ( التابعیین لل .System Taۆ1esp ace‏ 


مثال تطبيقي 5.14: 


بعد تنفيذ النقطتين الأولى و الثانية من طركقة(النتفيذ: 


ALTER TABLESPACE app_data RENAME DATAFILE 
'...loradata\db01\app01.dbfy®'...loradata\db01\app02.dbf" 
TO 
'...loradata\db02\app01.dbf' , ' ...loradata\db02\app02.dbf'; 


:Alter Database مIدختسlب‎ 


یمکن نقل ملفات ال و۴1۲ و٤(‏ باستخدام القاعدة التالية: 


ALTER DATABASE database's name 
RENAME FILE 'filename' , ['filename'] 
TO "filename" , ['filename']; 


طريقة التنفيذ: 


اغلاق ال eھطD4)4.‏ 

نسخ ملف ال ۴11۲ 0a‏ الى المواقع الجديدة (القيام بعملية النسخ كما في نظام التشغيل › أي في 
الويندوز يستخدم الفأرة „(PASTE ڍy COPY ga‏ 

تشغيل ال موو ط هاه( في حالة اÛ .Mount‏ 

تنفيذ القاعدة السابقة. 

تشغيل ال موو طهاه0 في حالة «ء0p.‏ 
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شروط الاستخدام: 
ه يجب أن تكون ال مووطه)ه0 في حالة ال .Mou n)‏ 


يجب تواجد ملفات ال و٥آ۴ ()a‏ المراد نقلها في الموقع المحدد في القاعدة. 
یمکن نقل ۴٥‏ و٤‏ التابعیین لٰل lespaceۆTa .System‏ 


تذكر: هي نفس القاعدة التي استخدمناها لنقل أو تغيير اسlaء .Redo Log Files JI‏ 


مثال تطبيقي 5.15: 
بعد تنفيذ الثلاث نقاط الأولى من طريقة النتفيذ: 
ALTER DATABASE app_data RENAME FILE‏ 
'...loradata\db01\app01.dbf"‏ 


TO 
'...loradata\db02\app01.dbf'; 


:TABLESPACE WITH OMF 
"Parameter" بتحداالعامل‎ M۴ تتبع نظام ال‎ ۲۹ ط1٥٤م‎ 4٥٥ یمکن تکوین‎ 
واستخدام قاعدة ال‎ Taۆblespace‎ Ji نییعبlتلl‎ Data Files Ji DB_ CREATE FILE DEST 
مع عدة اختلافات مثل عم الضڑیرة لذکر اسم ال ی٥۴ و04 في‎ CREATE TABLESPACE 
القاعدة,.‎ 
CREATE TABLESPACE tablespace's name 
[DATAFILE [filename] [SIZE number [K|M] ] ; 
:Data Files J| تکون‎ 0M ط۲۹ بنظام ال‎ 1٥٤م‎ 2٥e عند تکوین ال‎ 
)5.16 (کما في المثال‎ 100MB Defauاt حجمھا ال‎ 
مع عدم تحديد أقصى حد‎ )۸1 10٤×1۴۸ [( ه تستخدم الطريقة الأوتوماتيكية لزيادة حجمها‎ 
.(UNLIMITED) pجحلJل‎ 
:5.16 مثال تطبيقي‎ 


لتکوین ۸٥٥‏ م٥‏ 1 ط۲۹ بنظام ال 0۴ یجب تحدید العامل "Para me)e۲"'‏ 
DB_CREATE_FILE_DEST‏ ثم کتابة التالي: 


CREATE TABLESPACE new_data; 
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:QUERYING INFORMATION 
للحصول على معلومات حول ال وء همءء1ط 1 يمكن استخدام:‎ 
مم1ط ۲4 في‎ 4٥6s یوفر هذا ال س۷1 معلومات حول جمیع ال‎ :DBA_"ABLESPACES 
(Temporary, Undo) Tablespace JI Ãyعgiy‎ Tablespaces J| اسم‎ Jûa Database J| 
وغیرھا.‎ )[0caا1اy,‎ Dictiە‎ "4 y( E×)ء”‎ ٤s ونو عية ادارة ال‎ 


$A BLESPACE *‏ : توفر معلومات عن اسم و رقم ال 6s‏ ھم٥[1طا۲۵.‏ 


للحصول علی معلومات حول ال ۴٥۶‏ 4)4( یمکن استخدام: 


:D(BA_DATA_FILES *‏ یوفر معلومات حول ال ۴۶ D4٤4‏ مثل اسم (٤4 ۴1٥۶‏ وال 
espaceاbه"‏ التي ينتمي لها ال ۴1۲ )0 وحجم ال وم۴ و٤(‏ وغيرها من المعلومات. 


:YŞDATAFILE °‏ يوفر معلومات حول ال Data File JI ll Jû Data Files‏ 
line)‏ 8 ,ineاOn)‏ › حجم ال ئم۴1 54)a‏ وغیرها. 
للحصول على معلومات حول ال sع۴11 5٥1p‏ يمکن استخدام: 


JI و‎ Temp Files صم‎ Jûa Temp Files J| يور منڭلومات حول‎ :DBA_TEMP_FILES 
وغیرها من المعلومات.‎ 1٥, التي ینتمي لها ال ۴1۲ م ,آ٥۲ وحجم ال وم۴ م‎ "هbاespace‎ 


Temp File JI Ãll Ja Temp Fileۆ‎ Ù يوفر معلومات حول‎ :YŞTEMPFILE 
وغيرها.‎ emp ۴¡1es حجم ال‎ › )Onاine,0‎ 8 fline) 
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الول الس امس 
السيجمنت و خصانص التخزين 


SEGMENYS & STORAGE 
STRUCTURES 


SEGMENTS 


ال ٤مصعهS‏ هي احدی مکونات ال Structure‏ 0gica1ا‏ وتأتي بعد ال 6٥ص٥1‏ ط۲4 في الترتيب › 
یمکن لل 4c‏ مءم1ط ه۲ أن تحوي آکثر من )"٥ط‏ عم کما یمکن لل ٥.۸۲‏ "ع٥5‏ أن تتکون من اکثر من 
.Extent‏ 


يوجد عدة أنواع من ال ۸۲ع مثل: 


.TABLE SEGMENT 

.TABLE PARTITION SEGMENT 

. CLUSTER SEGMENT 

.INDEX SEGMENT 
.INDEX-ORGANIZED TABLE SEGMENT 
. INDEX PARTITION SEGMENT 
.TEMPORARY SEGMENT 

. UNDO SEGMENT 

.LOB SEGMENT 

.NESTED TABLE SEGMENT 


سوف يأتي ذكر کل نوع لاحقا. 
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DATA BLOCKS 


هي أصغر وحدة تخزين في الأوراكل ویتم تحديد حجمها بواسطة العامل "إم) م۳ ۲4و۶" 
(B_ BLOCK SIZE‏ عند تکوین ال مء طهtهD‏ ولا یمکن تغيير الحجم فیما بعد. یتکون ال و٤5‏ 
Block‏ من: 


:B LOC HEADER °‏ يحتوي علی معلومات حول ال gi Data B1‌0ck‏ ع4 ) Data, Index,‏ 
0ا ۲ه). يحتوي أيضاً على ال راها٤ءء1۲‏ ء1[ط11 الذي يوفر معلومات حول ال وهاطه٣‏ التي 
لھا بيانات (sس Da) R0‏ ) في ال ء810 044 . ومن أجزاء ال Header‏ )oeا8B‏ ایضاً ما 
يعرف باسم راه)ءءإ01 س٠8‏ الذي يوفر معلومات حول البيانات (sس٥8)‏ المخزنة في ال )810 
مٹل Block Header Û ja ريخÎلا ءjجلا . Row Address ÛÙ|‏ هي Transaction Slots Û‏ 
التي تستخدم عندما تحدث تغيرات في البيانات "وس80" نتيجة للمهمات "ود "a١440‏ 
المختلفة. 


."R هي المساحة التي يتم تخزين البيانات بها "4س0‎ : ۲۸ SPACE 
Data Space Jly Block Header J| ja JÛ هي مIwحã خıة تساعد‎ :FREE SPACE 


على التوسع في الحجم اذا لزم الأمر. في حال حدوث عمليات كثيرة تسبب أخذ مساحة منها ثم اعادة 
مساحة لھا بشکل متکرر یحدٹث ,)ے٤ ٥,‏ ه۴۲ ويقوم الأوراكل بعملية ٥ء41٥٥‏ لها. 


تذكر: عملية ال عدذعءءء1ھ٥٤‏ من درس |ل .Locally Managed Tab1espacê‏ 


Data Files JI ê Checkpoint JI pês og Sequence Number ÛJI pۉړر تذکر2: یتم تخزين‎ 


8 
ee 
EE PAGE 


1 


TA SPACE 


الرسم 6.1 


ملاحظة: الأسهم في الرسم 6.1 تشير الى الطريقة التي تكبر بها مساحة كل من ال #ءوم؟ واد وال 
Be Her‏ وهي طريقة عكسية » من أسفل الى أعلى ومن أعلى الى أسفل على التوالي. 


97 


:BLOCK STORAGE PARAMETERS 


ع يتم تكوين 111٥‏ أو عنصر أخر "زا0" یمکن تحدید عوامل تتحکم في ال ء٥81‏ ۾ التي 
تنتمى لهذا العنصر. تحديد هذه العوامل مهم جداً > لأنها تعمل على توفير مساحة كبيرة وتحسين الاداراة 
والعمل. 


:P)1۴REE ٠‏ عند تحديدها › يتم حجز مساحة من حجم ال ء810 تخصص للزيادة المتوقعة في 
البيانات "وس80 و4(" النانتجة من تغيير "ول مل" البيانات R0 ws"‏ و4(" في ال 
Bloc)‏ الحجم ال (efu)‏ لھا ھو 10%. 


:P) USED ۰‏ تمثل الحجم الأدني للبيانات "وس80 ه04" في ال )ء810 الذي اذا قل حجم 
البيانات "س R0‏ و4(" المخزنة داخله عن حجم ال S٤[‏ ا۲٥٤۴‏ ۰ یتم تحویل ال )م81 الى 
قائمۂ ال ٤1ا٥٥ ›۴٣‏ الحجم ال )ا (0e u‏ هو 40%. 


:FREELIST ®‏ یمن لل m۲‏ عSe‏ الواحدة أن یکون لها آکثر من )ا٥۴۲۲‏ واحدة بتحديد العامل 
Default Û|  FREELISTS‏ هو لكل Segment)‏ واحدة › قائمة ام۴6 واحدة. 


Block Û „û "Transaction Slots" Ji عند تحدیدھا يتم حجز مساحة‎ :[N]"R ANS 
۲ه لتخزين البيانات حول المهمات التي تجري. فهي تحدد الحد الأدنى من المهمات‎ 
› 3 التي یمکن أن تجری على ال ه81 في نفس الوقت. اذا تم تحديدها ب‎ "آransaction"‎ 
بحيث يمكن أجراء ثلاث مهمات على الأقل على‎ 1۲4,2٥ )1٥۸٧810٤ءرثالث فذلك يعني آنه یخصص‎ 
ال )810 في نفس الوقت » عن الضڑورة يمكن تخصيص مساحة من ال م٥ےم؟ ۴۲۲۲ في ال‎ 
.1 هو‎ Defa u1 أخرى› ال‎ "rAhl action S1ots إضافة‎ Block 


Block J „û "Transaction Slots" Ji عند تحدیدھا یتم حجز مساجة‎ :MAXTRANS 
4ظ لتخزين البيانات حول المهمات التيإتجري. فهي تحدد الحد الأعلى من المهمات‎ 
› 200 التي يمكن أن تجرى على آل81061«في نفس الوقت. اذا تم تحديدها ب‎ "آاansactions"‎ 
فذلك يعني أنه يمكن أجراء 200 مهمة على الأكث علىال ء810 في نفس الوقت› ٤اuںه؟ء50 هو‎ 
.255 


ملاحظة: يقصد بال )و٥٥۴۲‏ بأنها قائمة "٤ء"‏ تحدد ال وعم[ التي يوجد بها مساحة خالية قادرة 
علی استیعاب بیانات جدیدة أو ال cksہ[8 .۴٣٤۲‏ 


مثال: 
في حال تم تحدید ال S٤5‏ ل P٤٥1‏ بنسبة 30% والÛ P1 FREE‏ بنسبة 20%: 


1- يتم ادخال بيانات "س٠8"‏ الى ال 810k‏ الى أن تصل نسبة البيانات المدخلة الى 80% أو أقل بحيث 
يجب أن يظل حجم من ال )810 فارغ وهو نسبة ال P٣] ۴R E٤‏ وهي کما ذکرنا 20% وھکذا یظل حجم 
فارغ من ال )ه810 في حال تغير بيانات »سه8 المخزنة في ال ء810 مثل تحويل قيمة أحد ال 

C0 LUMN‏ من حالة N11‏ الى قيمة فعلية. هذه المساحة الفارغة مخصصة لل 8٠s‏ الموجودة في 
حال تغير قيمها ولا يمكن اضافة و R٠‏ جديدة لتحل في الحجم الخالي الناتج من تحديد .PCTFREE ÛJI‏ 


2- في حال انخفاض بيانات ال سه8 المخزنة في ال عم[ أو تم حذف عدد من ال وس80 › لايسمح 
باضافة وس80 جديدة في ال ع 810 اذا لم تنخفض بيانات ال R٠ ۷s‏ في ال ء810 عن الحد المحدد ب 
۴٣D‏ وهو 30%. في حال انخفاض حجم بیانات ال RW‏ عن ۰30% یتم تحدید أن ال 810k‏ 
جاهز لاستقبال R0 ws‏ جدیدة (٤ء1ا ee‏ ۴). 
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MANAGING DATA BLOCKS 
يمكن إدارة ال ءء810 هه( بطريقتين احداهما يدوية والأخرى أوتوماتيكية وهما:‎ 


:MANUAL DATA BLOCK MANAGEMENT 


یتم استخدام Bloc) Storage Para nete‏ في تحدید حجم ال 0ks‌1ا8.‏ 


:AUTOMATIC SPACE MANAGEMENT 


یتم استخدام م ھ٤8‏ عوضاً عن ءا٥٥۴‏ لتحدید ال cks‏ ہ81 Used‏ وال cks‏ ہ81 .۴٣۵‏ یتم حفظ ال 
Bitmap‏ في ءء810 مختلفة تسمى .Bi) «2p pe4 810 cs )8M8s(‏ عندما یتم ادخال بیانات 
"Rows"‏ جديدة › يتم البحث في ال مه .)81 عن )ء810 يحتوي مساحة خالية مناسبة لحجم البيانات 
الجديدة المدخلة وعند حدوث أي تعدیلات على Blocks Û'‏ (مثل زيادة المساحة الخالية عن المساحة 
المشغولة) يتم تعديل ال مه811 لتوافق التغيرات التي طرأت. 

فوائد استخدام هذه الطريقة عديدة منها سهولة ادارة ال وم81 اذ یتم تحدید ال [٤؟ا P٤٥۲‏ و ال 
۴R EELST‏ بشكل أوتوماتيكي » تخصيصالميساحة للعناصر "ءءء زط0" بشكل أفضل › وأداء أفضل 
خلال عملیات ال 1 ]NSE‏ المتزامنة. 


4 


نقاط مهمة: 
1- يمكن استخدام هذه الطريقة مع يع 4مء1 ط14 Managed‏ yااocaا‏ فقط 


2- تطبق الطريقة على مستوى ال ٥ء‏ دمء٥1ط ٠۲4‏ أي يجب أن تكون جميع ال و٤٥ص‏ عم$ داخل ال 
espace‏ اbه"‏ تعمل بنفس الطريقة. 


3 لا يمكن تغيير الطريقة الى الطريقة اليدوية بعد أن ت تخدم. 


4- يمكن استخدام هذه الطريقة باضاف جأ SEGMENT SPACE MANAGEMENT ۸UTO‏ 
ا جlۀ .CREATE TABLESPACE‏ 


5- لا يمكن استخدام الطريقة مع ءءدمءء1طه تحوي أو قد تحوي على sو08_.‏ 
ملاحظة: يتم تخزين بيانات كبيرة بواسطة 108s‏ مثل الصور والفيديو وغيرها وسوف يتم التطرق لها في 
فصل لاحق. 
مثال تطبيقي 6.1: 
CREATE TABLESPACE APP DATA‏ 
DATAFILE '...\loradata\ldb05\appdata04.dbf"‏ 


EXTENT MANAGEMENT LOCAL UNIFORM SIZE 512K 
SEGMENT SPACE MANAGEMENT AUTO; 
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STORAGE INFORMATION 


للحصول على معلومات حول ال s)رمء”‏ عم يمكن استخدام: 
:DBA_ SEGMENTS *‏ يمکن الحصول علی معلومات حول اسم ال Seg e٤‏ ءال 
espaceاab r‏ التي تحوي Segment J|‏ <« عد Extents J|‏ في Data ÛJI ıدعy Segment ÛJI‏ 
ء0اB ٠‏ وغيرها من المعلومات. 
للحصول على معلومات حول ال ئ۸4 رع] d ٤×‏ عو یمکن استخدام: 
:D(BA_ EXTENTS‏ یوفر معلومات مثل رقم ال E×)۸۲‏ ورقم ال )م81 التي ینتمي لھا وعدد 
ال »810 ضمن ال E>).‏ وغيرها من المعلومات. 


للحصول علی معلومات حول ال ئ٤ہرع]×‏ £ ٥ع‏ یمکن استخدام: 


:DBA_FREE_SPACE °‏ یوفر معلومات مثل اسم ال عه مءم1ط ه۲ التي تحوي ال Ex)e٤‏ 
وال وم81 التابعة لها وغيرها. 
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UNDO SEGMENT 


تستخدم ال ۲٠٥رعءS‏ 100ا في حفظ نسخة عن البيانات قبل تعديلها بواسطة المهمات 
"nsactionsها"آ"‏ التي أجريت عليهاء مثلاً لكي يتمكن الأوراكل من استعادة البيانات قبل التعديل في حال 
طلب المستخدم )4 ط11هR‏ عوضاً عن ٤ن‏ ص٥٥‏ . یتم استخدام ال Un d0 Segment Header‏ لتخزین 
بيانات حول المهمات "ناوور وآ" الحالية التي تستخدم .Undo Segment JÛ‏ 


:Undo Segment J| من فوائد استخدام‎ 


ه لكي يتمكن الأوراكل من استعادة البيانات قبل التعديل في حال طلب المستخدم kءوط1[هR‏ عوضاً عن 
.Commit‏ 


ه لكي يتمكن الأوراكل من استعادة البيانات الأصلية في حال تعطل المهمة أو حدوث خلل طارئ لل 
stance‏ يتطلب عملیة ال .Rec0 very‏ 


للقيام بما يعرف ڊlصp .Read Consistency‏ 


ملاحظة: تستخدم المهمات المرتبطة ببعضها Undo Segment « "Serial Tra ns2 ci0"‏ واحدة فقط 
ويمكن للمهمات المتزامنة استخدام ذاتال .Undo Segê ٤‏ 


تذکر: یتم تخزین معلومات حول ال m٤‏ عه$S‏ ٥4ا‏ في: 
.Initialization Parameter File e‏ 
«Alert Log File‏ 
.Control File e‏ 


تذکر2: جاء ذکر ال 1۸۲ عمS‏ ٥ل‏ ہا في درس: 
.Undo Tablespace‏ 
.Offline or Online °‏ 


:System Change Number (SCN) 
Read ا" يتم تكوينه عند حوث أمر انصصه)» ويساعد في عملية ال‎ ہ1٩‎ ںue‎ N.ںہاط‎ e۲ ھو رقم ممیز‎ 


Redo Log «< Control Files JI في‎ SCN J| يتم تخزين‎ .NRecovery Û| Azle sy Consistency 
.Block Headers ۾‎ < Files 


تذکر: یقوم ال )ذه م )عمط بعمل تجدید لرقم ال S€©۸‏ في ال .C٥۸ ٤01 ۴1e‏ 


:Read Consistency 


هي إمكانية رؤية أحد المستخدميين البيانات الأصلية قبل التعديل بالرغم من قيام مستخدم أخر بتعديل البيانات 
في نفس الوقت. لحدوث ال رءمءاءزوره٤‏ 44ء8 يجب أن يكون المستخدم الأول قد طلب البيانات قبل أن 
يقوم المستخدم الثاني بتأكيد التعديلات على التغيرات بواسطة ٤نصصه)‏ » عندئذ يحضر الأوراكل البيانات 
المطلوبة للمستخدم الأول من ال Sg.)‏ 0لم لا. 
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مثال: 


1- يقوم المستخدم الأول بعمل مهمات على بیانات ال 6s[طه٣‏ ءءعرهام .ع تؤدي الى تغير البيانات مثل 
.UPDATE ule‏ 

2- يقوم الأوراكل بتخزين نسخة لبیانات ال ٣41٥‏ رامع قبل التعديل في ال d0 Seg” e4‏ €ا. 
3- يقوم المستخدم الثاني بطلب استخراج البیانات عبر استخدام Select * From Jû Query‏ 
oyesاEmp»‏ وعندها يتم تحديد رقم ال ©5 الذي يستخدم لضمان عدم عرض البيانات التي يحدث لها 
تغییر ولم یحدث لھا )زر mص٥C٤.‏ 

4- البيانات المعروضة على المستخدم الثاني هي البيانات قبل التعديلات التي أجراها ويجريها المستخدم الأول 
و هي البيانات المخزنة في ال Seg m٤‏ 0لم ا. 

5- يقوم المستخدم الأول بانهاء و تأكيد المهمات التي أجراها باستخدام ازصدصه) » فيتم تجديد ال .S€©١‏ 
6- يقوم المستخدم الثاني بعد قليل بطلب استخراج البيانات مرة خرٳ .Select * From Employees‏ 
7- البيانات المعروضة هذه المرة هي البيانات بعد التعديلات التي أجراها المستخدم الأول . 


:Snapshot Too Old Error 


عندما لا يستطيع الأوراكل توفير خدمة ال رءمءاءاوره٣ 8٠44‏ يظهر هذا الخطأ للمستخدم. يمكن أن يظهر 
الخطاً عندما يطلب المستخدم الثاني رمں يكون البيانات المستخرجة طويلة جداً» بحيث قبل أن ينتهي ال 
رامQu‏ من العمل يحدث أمران» الأمك الأول هو أن المستخدم الأول طلب ٤ن‏ ص٠٥‏ على البيانات › والأمر 
الثاني أنه تم استخدام ذات ال ۸۲٥ص‏ ع٥5‏ ولا من قبل مھمة آخری بحيث تم تغيير البيانات 
.Ûndo Segment JI aê "Overwritten"‏ 

باستخدام العامل U NDO_REFEN TION "Para nete"‏ یمکن تحدید کم من الوقت یسمح للبیانات 
بالبقاء في ال ٥4م 141e‏ 110ا وبذلك توفیر خدمةپال رء”ء)ءiو«ه٣ ٥44‏ 8. اذا تم تحديد قيمة العامل 
ب 900 » فهذا يعني أنه يسمح للبيانات البقاء لمدة 15 دقيقة. يمكن تحديد العامل في ال «0نخوz¡اi)i4م1‏ 
Parameter File‏ › ويمکن تعدیلھ دايناميكياً ڊو اسطة .ALTER,ŠY¥S 1EM‏ 


ملاحظة: اذا كان حجم ال مءومءء[اطهآ ٥لا‏ صغير» يمكن أن ا تظل البيانات للوقت المحدد بالعامل 
UNDO_RETENTION‏ » حيث يتم استخدام عمليات حسابياةلتبديل البيانات المخزنة. 


:UNDO SEGMENT TYPES 


:SYS1EM UNDO SEGMENT *‏ تتکون ضمن ال 4٥٥‏ م٥۲۵1‏ ۳ءtءرS‏ عند تکوین ال 
ata se‏ لتوفر خدماتها للعناصر "ء)ءءزط0" الموجودة ضمن ال .System 1 4b[esم ace‏ 


:NON-SYSTEM UNDO SEGMENTS °‏ عندما يوجد Tab1 espace‏ ي Database JI‏ 
غیر ال esp 4 ce‏ 1ط ھ1 System‏ › يجب توفر على الأقل واحدة Non-System Undo ja‏ 
Segment‏ في ال seھط‏ ھغھ لتخدم باقي ال 6s‏ ھمء1eطا14.‏ 


:DEFERRED UNDO SEGMENTS ®‏ یمکن تکوینها عند وضع ال 6ےم٥1ط‏ ۲۵ في حالة 


fine‏ › اذ یمکن أن تستخدم في عمل )ا ھط[1ه8R‏ للمهمات "۹٥1٤ء‏ ھی ,ه۲۲" التي قد تحدث 
عند تحویل ال ce‏ ےم 1ط ھ۲ الى حالة اÛ .Online‏ 
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MANAGING UNDO DATA 


يوجد نوعان لإدارة ال و٤0‏ 0لا في الأوراكل هما: 


.AUTOMATIC UNDO MANAGEMENT ° 
.MANUAL UNDO MANAGEMENT ° 


سوف يتم التطرق فقط الى النوع الأول في الكتاب. 


:AUTOMATIC UNDO MANAGEMENT 


يتم تخصيص ء٥4‏ مءء1طا14 140ا واحدة ذات مساحة كبيرة لكل مء« و٤وه[.‏ يتم التحكم في البيانات 
الموجودة في ال مءدمءء1ط 14 0لا بشكل أوتوماتيكي من قبل ال S٥۷۲‏ ء1ء0۲4. يتم تسمية أسماء 
Undo Segment‏ طبقاً للطريقة التالية 1Ş‏ ا _S¥SSM/‏ مئل ١1$‏ SM؟S؟¥S_.‏ 

لكي تعمل طريقة ال Automatic Undo Management‏ يجب توفر 2¢ مع[ اھ1 0لا واحدة في 
حالة ٠۷ا‏ ۸. بالرغم أنه يمكن أن تتواجد أكثر من ءءومءء1اطه1 0لا في ال مء ط٤ھD‏ ولکن لا یمکن 
أن يكون أكثر من واحدة في حالة م۷إ)۸. 

لاستخدام هذه الطريقة يجب تحديد العامل_"'etefص U ND0O_MANAGEMENT "Para‏ بالقیمة 
U0‏ ۸ في اÛ Parameter File‏ iatiohاهtiا].‏ لا يمكن تغيير قيمة العامل بطريقة دايناميكية بعد 
تشغيل ال موو ط و٤04‏ /القيمة اJ .MANUALQa4¢efault‏ 

لتحدید ال ce‏ 2م٥۲۵1‏ 0لا التي سوفا یتم التحكم ب بوlسصطة Automatic Undo‏ 
Management‏ ڍجب UNDO_TABLESPACE '"P4frameter'"'Jمlعl ıı‏ في ال 

D44 طھse 0لا واحدة في ال‎ 12 ا1esم2‎ ce !ل أن يكون ھتالڭ‎ › ]nitialiation Parameter File 
عندئذ لا يشترط تحديد هذا العامل "١ء٥ 4٣إه۶". يمك,تغيير قيمة هذا العامل بطريقة دايناميكية بواسطة‎ 
.ALTER SYSTEM 


مثال تطبيقي 6.2: 


لتغيير قيمة العامJ U[ND0O_" A BLESPACE‏ بشکل داینامیکي (للتحدید م 2مم1ط ۲4 أخرى في حالة 
:(Active‏ 


ALTER SYSTEM SET UNDO_TABLESPACE = UNDOTBSPACE; 


أو عبر ال م1مو ه٥‏ باتباع الخطوات التالية: 


ادخل الى ال Console‏ عڊر .Standalone‏ 

م اضغط عڵٿ اسم Database Û|‏ لکي تظهر نافذة تطلب من اسم المستخدم و كلمة السر. 

٠‏ أدخل اسم المستخدم وكلمة السر مع التاكد من اختيار S۷58584۸‏ عوضاً عن إوصإه.. 
اضغط على .Instance Manager Û‏ 

.Configuration Jزآغ‎ biض)‎ 

٠‏ اضغط على قائمة 0ل لا. 

.Undo Tablespace Û pl Current Undo Tabl1espace ةمnئl أختر من‎ 
.۸م‌ماy اضغط على‎ 
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:Snapshot Too Old Error 


يمكن أن يحدث هذا الخطأ ايضا اذا ما تم تغيير ال #ءءaمء1eط n0 ۲a‏ ا( بواسطة ALTER JI‏ 
SYSTEM‏ أو عبر ال 1eمsر٥€‏ ) وکان ما یزال ر Que‏ یستخرج البیانات من ال 1espaceۆTab Undo‏ 
التي تم تغييرها. 


ملاحظات: 


1- في حال لم يتم کتابة جل CREATE DAT ABASEةج „ê UNDO TABLESPACE JI‏ « 
وكانت قيمة العامل UND0O_MANAGEMENT‏ تساوي ۸0۲0 » فإن الأوراكل سيرفر يقوم بتكوين 
espaceاab" €n do‏ بشكل أوتوماتیكي بمىسمى 858 7N(01ا_$؟¥S؟.‏ 

2- يمکن حذف ع٥2‏ مء٥1ط‏ ھ٣‏ 0ل € باستخدام جملة PROP "A BLESPACE‏ التي جاء شرحھا 
سابقاً» ولکن لا یمکن حذف ال ھم ء٥1‏ ط٣‏ ٥ل‏ ہا اذا كانت تستخدم بواسطة .(Active)Insta nce J|‏ 


تذکر: 


gİ CREATE DATABASE ÛJI ةlaج م5 1ط ھ٣ 40ہ[ بطريقتيين <« إما عبر‎ 2 ce يمکن تکوين ال‎ -1 
.CREATE UNDO TABLESPACE ژأaڄ عبر‎ 
.Undo Tablespace Û ي درس‎ Automatic Undo Management J| رÛذ‎ slج‎ -2 


مثال تطبيقي 6.3: 


يمکن حذف ال ٥4ص٤۲41‏ €0 بواسطة ROP "A BLESPACE‏ ولکن یجب علی کل المھمات 
التي تجري في ال ln d0 abl esp 2e‏ ان تنهي عملھا قبل اتمام«غملية الحذف» يمكن معرفة اذا ما کان 
هنالك أي عمليات تجري على ال مء ومءء1طه٣‏ 0ل 01ا أو أي“خءةمءء1ط 14 من خلال كتابة التالي: 


SELECT Z.NAME, X.STATUS 

FROM V$ROLLNAME Z, VŞ$ROLLSTAT X 

WHERE Z.NAME IN 

(SELECT SEGMENT_NAME FROM DBA_SEGMENTS 
WHERE TABLESPACE_NAME = 'UNDOTBS') 

AND Z.USN = X.USN ; 


اذا كانت قيمة ال $1۸18 هي PENDING ONL|1NE‏ فهذا يعني أن ال 4۲م٥1ط‏ ۲۹ لا یمکن 
حذفهاء أما اذا كانت القيمة هي PENDING OFFLINE‏ فهذا يعني أنه یمکن حذف ال e٥وم۶٥1ط۲4.‏ 


:Resource Manager 


يمكن استخدام ال ام وور هة[ ١ء۲ u‏ 0ء8 للتحكم بالنظام بحيث يتم منع المستخدميين أو مجموعة من 
المستخدميين من استهلاك مساحة كبيرة لل وا0 ملا بحيث يتم تخصيص مساحة قصوى "عzزءx۾۷1"‏ 
لكل مجموعة لاستخدامها في تخزين ال و٤٥‏ 0ل ,. يتم تخصيص مساحة قصوى بتحديد ال 

.UNL1M17٤( والذي هو في الحالة الإفتراضية ")[ںوfء 5" محدد بالقيمة‎ UN D0_ P001 
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QUERYING UNDO INFORMATION 


يمكن استخدام ال ۷1٥s‏ التالية للحصول على معلومات حول ال d0 Seg”‏ ا: 


:۷ŞUNDOSTAT °‏ يساعد في تحدید حجم ال ce‏ م٥‏ 1ا۲ 0ا »اذ یوفر معلومات حول 
عمل ال ce‏ ےم ء٥۲۸1 d٥‏ ہا وضغط البیانات علیھا خلال 10 دقائق. 


SELECT BEGIN_TIME, END_TIME, UNDOBLKS 
FROM VŞUNDOSTAT; 


:D(BA_ N ROLLBACK_SEGS °‏ للحصول على معلومات حول جمیع ال :.٤۲‏ عع 011٥‏ فقي 
ال .D ata base‏ وحدها فقط توفر بیانات حول .Offline Segment J|‏ 


SELECT SEGMENT_NAME, TABLESPACE_NAME, OWNER, STATUS 
FROM DBA_ROLLBACK _SEGS; 


.Online Segments JI gaج توفر اسماء‎ :YŞROLLNAME 
SELECT USN, NAME FROM VŞROLLNAME; 


:YŞROLLSTAT °‏ توفر بیانات.خول ال 01ine Seg mes‏ مثل حجم ال "٤٤s‏ عمS‏ وعدد 
ال Ex) )s‏ وغيرها. يمکن عمل Join‏ مع ŞROLLNAME Û‏ ۷ بواسطة اÛ .USN‏ 


SELECT A.NAME , B.EXTENTS 


FROM V$ROLLNAME A , VŞROLLSTAT B 
WHERE A.USN = B.USN; 
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اذمل اساج 


أدار التايل و الاندكسصس 
والكونبسنرانيت 


Managing{tables & indexes & 
constraints 
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STORING DATA 


یتم تخزین ال 0۸۲۸ في أوراکل علی شکل وس80 و ک«صں‌اه٥‏ في ال 16ط ۲۵. يوجد عدة آنواع من ال 
"bes‏ مثل: 


"ABLES‏ )أو Tables‏ arاRegu):‏ هي ال ما4٣‏ التي يتم معظم العمل عليها والتي يكون 
التحکم بتوزیع بال 8٥W‏ فیھا من وظائف ال .O r21e Sever‏ 


:PARTITI[ONED TABLES °‏ يکكون Table JÛ‏ أکثر من جزء "٤٤و٣"‏ كل جزء 
عبارة عن "٥٣۲٤‏ عع S؛‏ کل رع عع؟ یمکن ان تتواجد في ٥٥‏ 2مءء1ط ۲1 مختلفه. 


:][NDEX-ORGANIZED TABLE °‏ یجب تخصیص ال Key‏ ryھہ1mا۴‏ لل b1e‏ ھ٦‏ ویتم 
تخزين ال ×۴ وال م[اط ه٣‏ في ذات المساحة › وذلك عکس ال ٥1ا۸٣‏ إواںعمR‏ التي اذا تم تكوين 
×۴ لها (الإثنان في مساحة مختلفة .("Separate Storage"‏ 


:)LUS1ERED "ABLE‏ يمكن أن تتكون من ء[ط 1 واحدة أو مجموعة من ال وم[طه۲ 
التي تستخدم مع بعضها بحيث تتشارك نفس ال وم81 ۾4(. یوجد ما یعرف باسم r‏ مtیں[اC‏ 
ره الذي يحدد ال وس8 التي يجب أن تخزن مع بعضها البعض. 


:DATA TYPES 


يوفر الأوراكل مجموعة من يمم رآ هه لتخزين البيآثات › تتبع ثلاثة أنواع هم Scalar, Collection,‏ 
«Relationship‏ 


:Scalar Data Types 
:Scalar Data Types بعض أنواع ال‎ 


:CHAR, N CHAR‏ توفر مساحة ثابتة "1٤ع‏ «ع8-1ء×۴1" لتخزين الأحرف 
."Characters"‏ المقصود بالمساحة الثابتة أنه عند تخصيص مثلاً و»)ر8 10 وتم شغل 7 
8 لتخزين البيانات» لا تعتبر ال وم)رط3 المتبقية مساحة خالية بل مساحة مشغولة. أقصى قيمة 
(مساحة) يمكن اختيارها هي 2000 بايت لكل س80 مع العلم أن القيمة ال )إاuںهfء0‏ هي 1. تختلف 
NCHAR‏ عن CHAR‏ أن الأولى يمكن أن تخزن إء)ء4إ2ط٤‏ م هء1 ما التي توفر خدمة تعدد 
اللغات. 

:YARCHAR2, NVARCHAR2‏ توفر مساحة متغیرة "1ع" 1e-1eطھriھ‏ ۷" لتخزین ال 
امهم“ ×. المقصود بالمساحة المتغيرة أنه عند تخصيص مثلاً وه) ر8 20 › واحتاجت البيانات 
المخزنة في ال صصںاه٤‏ الى وم٤رط‏ 15 فإنه يتم استخدام وم ر8 15 فقط من المساحة الخالية 
لتخزين البيانات › ولا يتم حجز المساحة الكلية المحددة. أقصى مساحة يمكن اختيارها هي 4000 
بايت لكل س80 مع العلم أنه لا يوجد قيمة )اده( ( يجب تحديد القيمة). تختلف 
ARCHAR2 ùe NVARCHAR2‏ ۷ أن الأولی یمکن أن تخزن c٥ de C124)‏ 1ہ ا التي 
توفر خدمة تعدد اللغات. 

38 توفر مساحة متغيرة لتخزين الأرقام. يمكن أن تستوعب المساحة أرقام تتكون من‎ : NUMBER 
خانة.‎ 
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۵ ۳ : توفر مساحة ثابتة لتخزين التاريخ والوقت. توفر سبع خانات للقرن والسنة واليوم 
والساعة والدقيقة و الثانية وأقصى تاريخ يمكن أن يخزن هو ال31 من ديسمبر لعام 9999 › أما أقدم 
تاريخ يمكن أن يخزن هو يناير من عام 1.4712 قبل الميلاد. 

:"]MESTAMP‏ توفر خدمة مماثلة لل ۸1۳۴ عدا أنها توفر مساحة إضافية لتخزين أجزاء 
الثانية. توفر 9 خانات لتسجيل أجزاء الثانية (0.987654321 ) والعدد ال ٤اuںوfمD‏ هو 6 خانات. 

:r"1[MESTAMP WITH TIME ZONE‏ توفر خدمة ممlأlة TIMESTAMP Ji‏ › !ل 
انها توفر مساحة إضافية لعرض الفارق الزمني بين المستخدم والتوقيت العالمي (توقيت جرينتش). 
يظهر الفارق على شكل عدد من الساعات والدقائق فقط. 

:]]|MEST AMP WITH LOCAL TIME ZONE‏ توفر خدمة مماثلة لل 
"]|MESTAMP‏ » إل انها توفر مساحة إضافية لعرض ال eى‏ 7⁄0 1n‏ «10وومS؛‏ الذي 
يستخدم في إدخال البيانات بين فروع الشركات البعيدة عن بعضهاء أي في حال ادخال البيانات من قبل 
المستخدم الأول الذي بينه وبين المستخدم الثاني زائد 3 ساعات زمنية › فإن المستخدم الثاني يرى 
توقيت إدخال البيانات بتوقيته هو ( زائد 3 ساعات زمنية) و ليس بتوقيت المستخدم الأول الذي أدخل 
البيانات. يظهر الفارق على شكل عدد من الساعات والدقائق فقط. 

2000 توفر مساحة متغيرة لتخزين ال )ة٥ رإه81. أقصى مساحة يمكن اختيارها هي‎ :۸0W۷ ٠ 
بایت.‎ 

:10NG RAW‏ توفر خدمة مماثلة لل سه8 ولكن مساحة أکبر 268 (لا ينصح باستخدامها) 

ه :10N6G‏ توفر مساحة كبيرة لتخزين البيانات › يمكن أن تصل المساحة الى 268 (لا ينصح 
باستخدامهاء ویفضل استخدام ٥1.08‏ أو .))N٤C108‏ لا یمکن لل ٥1ط‏ 14 أن تحوي أكثر من 
l108‏ واحدة. 

.Character Data Û| نڍjختل‎ 4G BAW توفر‎ :C 10B, NCLOB ° 

gy Binary Images Jia Unstructured Data ڻيزiil‎ 46B توفر مساحة‎ :BLOB 
.Documents 

:B۴] LE ۰‏ باستخدامهاء تستطيع تخزينبيانات خارج ال موو طه)د 0 في ملفات خارجيةء يمكن أن 
يصل حجم الملف الخارجي الى 468. 

:ROWID, UROWID °‏ توفر مساحة k٥‏ رط 10 لتخزین رقم ممیز لکل سه8 في ال 
6ط )هط ليستطيع الأوراكل تحديد ال 8٠W‏ بسلرعة أكبر عند البحث على البيانات. الفرق بين 
UX ROWIDs ROWID‏ أن الأخیرۃ توفر میزۃة تسجیل رقم ممیز ل RW‏ تتبع ]ء014-٥۸‏ 
ئه ( أي من نوع مءوطه٤هD‏ اخر غير الأوراكل), 


:Collections Data Types 
يوجد نوعان فقط هما:‎ 
عبارة عن مجموعة مرتبة من البيانات التي تتكون‎ :YARY|NG ARRAYS (VARRAY) ® 
من نفس ال ٠م رآ و٤ه (مثلاً جميع البيانات أرقام).‎ 


:NESTED "ABLES‏ عبار ة عن مجموعة غير مرتبة من ال Rs‏ › تخزن ال 80۷s‏ بشكل 
منفصل عن ال ٥1ا4٦‏ بحیث یوجد وصلۂ ۲ع ہ1٥۴"‏ من کل 8٥W‏ الی ال eاطھ٣.‏ 


:Relationship Data Types (REFS 


يتم استخدام ءم)م ذه۴ لتدل على بيانات مخزنة في وم1ط ه1 مختلفة. 
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MANAGING TABLES 


:CREATE TABLES 


لتکوین ٥1ا۲‏ ۰ یتم استخدام جملة (PRA E٤ "A B1٤‏ التي من المفروض قد تعرفت عليها بالتفصيل 
خلال دراستك للامتحان الأول t٥ 3Q"‏ «0ن)0Qucإاما".‏ لكي يستطيع المستخدم تكوين ٠1ا1‏ في ال 
Schema‏ الخاص به › يجب أن يکون لدیھ CREATE TABLE privilege‏ › أما لتکكوين 1ھ في 
Seh 8s‏ لمستخدمين أخرينء يجب أن يكو دي4 .CREATE ANY TABLE privilege‏ 


عند تکوین ال ۶٥1ھ :٣‏ 
توزيع كل ٥1ط ١4‏ على مءءومءء1ط14 مختلفة عن ال ومومو [ط ه٣‏ التي تحوي ملم ا 
.Indexes gyÎ Temporary Segments yÎ Segments‏ 
٠‏ استخدام نظام ل Ma" age‏ رااهء0[ (أي بدون استخدام جملة ال معوإهم)S)‏ لتجنب ال 
.Fragmentation‏ 


مثال تطبيقي 7.1: 
لتكوين Ma24 141٥‏ yاادء‏ 0[ يمكن كتابة: 


CREATE TABLE'HR DEST 
(FIRST VARCHAR2 (10), DAST NUMBER); 


أو يمكن اضافة التالي: 


CREATETAÃBLE HR.TEST 
(FIRST VAREHAR2 (10), LAST NUMBER) 
TABJÊSPACE EXAMPLE 
PÇTFREE 10 PCTUSED 20 
MAXTRÊANS 200 MINTRANS 1; 


على اعتبار أن ذکر »۲ABLESP ACE EXAMPLE‏ یدل على اسم ال ٥٥و‏ موه1ط ه۲ التي تحوي ال 
ما وهي في هذه الحالة ء»2مءء1طه٣‏ مامص ه×5٤.‏ وفي حال عدم ذكر هذه الجملة يتم اختيار ال 
Default‏ وهي عادة ما تکون ال ace‏ 1espا‏ ھ1 .System‏ مع العلم آنه تم تکوین ال 1۲ا۲ في ال 
Schema‏ الخاصة بالمستخدم HR‏ . 


أو عبر ال #اموهC‏ باتباع الخطوات التالية: 


ادخل الى ال .Standalone رڊۈعe Console‏ 

اضغط على اسم ال مووطه)ه لكي تظهر نافذة تطلب من اسم المستخدم و كلمة السر. 
أدخل اسم المستخدم وكلمة السر مع التاكد من اختيار 84 $۷90 عوضاً عن إومإه.. 
اضغط على + بجانب .Schema Manager J|‏ 

اضغط بواسطة الزر اليمين على م[ط ه٣‏ ثم اختر ٥۲٠١4٤٠‏ من القائمة. 

ادخل المعلومات المطلوبة (مثل اسم ال 1۲ط )٣۵‏ ثم اضغط على رامم۸ 

یمکن اختیار Create لsiہع ¡za‏ عوضاً عن C۲٥)‏ لتسهیل تکوین ال ۲[ط۲۵. 
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مثال تطبيقي 7.2 
لتكوين Dictionary Ma24 141e‏ يمكن كتابة: 


CREATE TABLE HR.TEST2 
(FIRST VARCHARS2 (10), LAST NUMBER) 
TABLESPACE EXAMPLE 
PCTFREE 10 PCTUSED 20 
MAXTRANS 200 INITRANS 1 
STORAGE (INITIAL 200K NEXT 200K 
PCTINCREASE 50 
MINEXTENTS 1 MAXEXTENTS 5 
FREELISTS 1 FREELIST GROUPS 1 
BUFFER_POOL DEFAULT) ; 


في جملة ال ۾چ04غS‏ : 


. Extent Jgأ تحدد حجم‎ :INITIAL 

آNE×X:‏ عند زيادة حجم البيانات يتطلب ذلك اضافة ٤٠ع)>۴E›‏ حيث تحدد جحم ال "٤‏ )× الثانية. 
:P)1NCREASE‏ تحدد حجم ال ×٤‏ التالية (ليست الثالثة فقط › إنما كل ما يأتي بعد الثانية) 
باضافة نسبة مئوية. مثلاً في هذه الحالة”يصبح حجم ال وہ )× التالية 300K)‏ (2006+ نصف حجم 
.(Extent Û (%50)‏ 

.۲۵ التي یمکن أن تخصص لل 1۲ط‎ E81٤ الحد الأدنی من ال‎ :MINEXTENT 
.٣ه‎ (1٥ الحد الأقصی من ال یآگم)×E التي یمکن أن تخصص لل‎ :MAXEXTENTS 

.۲۸ عدد مجموعات ال tءiامعع۴ التي یمکن أن تخصص لل 1۲ا‎ :FREELIST GROUP 
6ء۴ ضمن المجموعة؛‎ 1it عدد ال‎ :FREELISTS 

(Default Keep, Recycle) lw 4l Iiãرط¦î‎ :BUFFER_POOL 


ملاحظة: لا يشترط كتابة كل عوامل ال م#عهإه)$ » اذ يمكن أخد القيمة ال )ا وء( لكل عامل. 


.Locally Managed Tabl1e J| تذکر: ينصح باستخدام‎ 


أو عبر ال ٠01ء٠٥‏ باتباع الخطوات التالية: 


ادخل الى ال s01¢ئCon‏ عڊر .Standalone‏ 

اضغط على اسم Database Û‏ لکي تظهر نافذة تطلب من اسم المستخدم و كلمة السسر. 

أدخل اسم المستخدم وكلمة السر مع التاكد من اختيار S584؟S۷‏ عوضاً عن إوصإه.. 

„Schema Manager Û + اضغط عٺى‎ 

اضغط بواسطة الزر اليمين على ٥1ج‏ ثم اختر ه٤ج٠إC‏ من القائمة. ثم ادخل المعلومات المطلوبة 
مث بlıنات Initial Size, Next Size, Increase Size by, Freelists, Groups, J|‏ 
.Buffer pool‏ 


.۸ اضغط على راصم‎ ٠ 
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:CREATING TEMPORARY TABLES 
یمکن تکوین 1۲ا۲۵ ۲۹۲yه م٥٥۲ لتخزین بیانات مؤقته تلزم فقط خلال القيام بأحد المهمات‎ 
أو طوال فترة عمل ال «هذووم؟» أي في الحالة الأولى يتم حذف البيانات بعد الإنتهاء من‎ "آransaction"‎ 
المهمة (مثلاً كتابة انصم_ه٤)» أما في الحالة الثانية يتم حذف البيانات بعد خروج المستخدم من ال‎ 
.Database 
«CREATE GLOBAL TEMPORARY TABLE pIدڏختwا‎ pî Temporary Taۆl]e‎ ùيوyكت‎ 
ولتحديد اذا ما كانت البيانات سوف تحذف بعد المهمة أو بعد انتهاء ال ره‌ذووم؟ يتم إضافة الجمل التالية:‎ 

:0N COMMIT DELETE ROWS °‏ تحذف البيانات بعد انتهاء المهمة. 

٥N COMMIT PRESERVE ROWS °‏ : تحذف البیانات بعد انتهاء ال «ه‌ذووم؟. 
تذكر: ال «م1وومS‏ من الفصل الأول. 
ملاحظة: یمکن تکوین ۷1ew s, 1], e× es‏ على ال em مەاaإy 141e‏ كأي 16ا۲4 أخرى. 
ملاحظة2: مھمات (INSERT, DELETE Jû) DML J|‏ التي تنفذ عل Y Temporary Taۆle ÛJI‏ 
تؤدي الى تکوین بیانات في .Redo Log Files‏ 
مثال تطبيقي 7.3: 
لتکوین ۲41٥‏ ۲4۲ه م٥۲‏ یتم حذف بیاناتهایبعد انتهاء ال ر ه‌زووم؟: 

CREATE GLOBAL TEMPORARY TABLE TEMP _ TABLE 


(TEMP_NAME VARCHARZ2 (25), TEMP_DATE DATE) 
ON COMMIT PRESERVE ROWS; 


:ALTERING TABLES 


يمكن القيام بعدة مهمات باستخدام lئجlة :ALTER TABLE‏ 


:Changing the Block Storage Parameters 


يمکن تغيير قيم PCED, PCT FREE, MAX TRANS,‏ ول یمکن تغییر ال ۲ھ م٥1ط‏ ۲ التي 
تنتمي لھا ا .MINTRANS y Table‏ 


ملاحظة: یمکن تغيير بعض عوامل جملة ال eعھ۲ه)؟‏ مثل ال )ینا ۴۲6. 
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مثال تطبيقي 7.4: 


ALTER TABLE HR.TEST2 
PCTUSED 40 
PCTFREE 20 

MAXTRANS 250; 


أو عبر ال م1مو ه٥‏ باتباع الخطوات التالية: 


ادخل الى ال „Standalone رڙڊe Console‏ 

اضغط على اسم Database Û‏ لکي تظهر نافذة تطلب من اسم المستخدم و كلمة السسر. 

أدخل اسم المستخدم وكلمة السر مع التاكد من اختيار 84 S۷955‏ عوضاً عن إوصإإه.. 

.Schema Manager J| + اضغط على‎ 

اضغط على + ال 1۲( ۲۵. 

اختر اسم المستخدم الذي يملك ال ٥1ط‏ ه٣‏ المراد تغيير خواصها (مثل 4/۸) 

اختر اسم ال م1ط ه٠٠‏ من النافذة اليمنى و اضغط عليها مرتين (أو بواسطة الزر اليمين للفأرة › اختر 
من القائمة ."ViewEdit Details"‏ 

٠‏ ادخل الى قائمة #عدإه)S‏ » وعدل البيانات ثم اختر رامم۸. 


:Manual Allocating Extents 
بشكل يدوي الى ال ٥1ط 11 باستكد(م#القاعدة التالية:‎ E×)٥" ٤و يمكن اضافة‎ 


ALTER TABLE [schema.]table&name 
ALLOCATE EXTENT 


[ 
SIZE number [K|M] 


DATAFILE ‘filename’ 
1 


اذا لم تتم كتابة جملة 1E number ]K|M[‏ › یتم تحدید حجم ال ٤ہم)٤×E‏ بناءاً على الحجم المحدد ب 
NEXT‏ » آما اذا لم تتم کتابة جملة ال DATA FILE ‘filename‏ » فیتم اضافة ٤×)‏ الى أي Data‏ 
۴e‏ ضمن ال e‏ ھمsع1ط‏ ھ۲ التي تحوي ال 1۲ط۲4. 

مثال تطبيقي 79 

لإضافة E×)٥.۲‏ بشكل يدوي يمكن كتابة: 


ALTER TABLE HR.TEST2 
ALLOCATE EXTENT; 
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:Moving Tables 


یمکن نقل 1۲ا۲ (بشرط أن لا تكون 1eط‏ 12 )Partitio 1e4‏ من espaceاrab‏ الى espaceاab r‏ أخرى 
باستخدام جم‘ .ALTER SYSTEM ge MOVE‏ 
عند عملية نقل ال ۲41٥‏ یمکن تغییر ال ؟م) ء۴۸۲4 معه۲ه)S‏ كما في المثال 7.6. 


ملاحظة: يمكن تنفيذ العملية لتغییر خواص ال ۴۸۲4٤٤٥۶‏ ۵ع۲4٥)$‏ دون نقل ال 1۲ ط۲4 الى 
espaceاab"‏ أخری (بنقل ال ۲۵1۲ من "٥۸۲‏ عم؟ الى أخرى) كما في المثال 7.6. 


ملاحظة2: يحب اعادة تعريف ال وم×م لم1 الخاصة بال ٠1ا4٣‏ التي تم نقلها لتجنب الأخطاء. 


مثال تطبيقي 7.6: 


ALTER TABLE HR.TEST2 MOVE 
TABLESPACE APP DATA 
STORAGE (INITIAL 300K) 

PCTUSED 30 
INITRANS 2; 


لتغییر Storage P24 ee‏ دون <نقڭال7 م۲41 الى 4e‏ 1espطا‏ ھ۲2 أخرى: 
ALTER TABLE HR.TEST2 MOVE‏ 
TABLESPACE EXAMPLE‏ 
STORAGE (INITIAL 300K)‏ 
PCTUSED 30;‏ 


مع العلم أن موقع ال ٤9712‏ ۸.۲] هو ال #cومءء1اطه٣‏ ءا#”ة×ع قبل المهمة. 


:DROPPING TABLES AND COLUMNS 


Truncate a Table 

باستخدام أمر "PRU NCATE TABLE‏ » يتم حذف جميع بيانات ال م1ط 14 واستعادة المساحة المشغولة 
(زيادة المساحة الخالية) التي كانت تشغلها البيانات. تعتبر "PRU NCATE TABLE‏ من أوامر ال 
DAA DEFINITION LANGUAGE (DDL)‏ وبالتالي فإنھا لا تسبب تکون ٥44‏ لہا علی 
اعتبار أن أوامر ال D1‏ لا يمكن أن يحدث لها kءوط1[1هR‏ (أي أنه لا يمكن استعادة البيانات بعد حذفها). 
ملاحظات. 


1- استخدام PR UNCA TE TABLE‏ يودي الى حذف ال 4٥×‏ م!] الخاصة بهذه ال 1۲ا۵٠.‏ 
2۔ لا یمکن استخدامھا علی ط۹٦‏ لھا علاقة ر ع٤٣٣۴‏ مع 16طھ٣‏ أخری. 
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مثال تطبيقي 7.7: 
يمكن للمستخدم 11۸ كتابة التالي : 
TRUNCATE TABLE TEST2;‏ 
أما ال 084 أو أي مستخدم أخر يملك الصلاحيات "ءءعء][¡ إ۴" اللازمةء فيجب ذكر ال ور طء؟: 


TRUNCATE TABLE HR.TEST?2; 


:Drop a Table 


یمکن حذف م1ط۲۸ بالکامل مع بیاناتھا باستخدام أمر ٤اB R0۶ A‏ . يجب إضافة جملة ‏ 
CASCADE CONSTRAINTS‏ اذا کان لل b[e‏ ھ٣‏ علاقۂ reign key‏ ۴0 مع 1eطھ۲4‏ أخری. 


مثال تطبيقي 7.8: 
لحذف مء1طه٣‏ بالكامل من ال مءوطa٤54?‏ 


DROP TABLE HR4TEST?2; 


:Dropping a Column 


یمکن حذف ہہ ںآه٥‏ والبیانات التي یحویھا من ال 1e‏ ط۲۹ باستخدذام ER۸ ۲۸ BE‏ ۸1۲ . قد تتطلب 
عملية حذف رص_ںاه٤‏ مدة طولية جداً و مءدم؟ ملا كبيرةجكآالل وم1طه٣‏ التي تحوي بيانات ضخمة 
جداً. في هذه الحالةء يفضل وضع ال u"‏ اه١‏ ضمن قائمة ال S٤5‏ ا.N‏ ال ثم حذفه بعد الأنتهاء من وقت 
الذروة (أي عندما تكون المهمات التي تجري على ال ٥1طه٣‏ قليلة). 

وضع ال رص ںاه) في حالة ال 7٤5ا‏ Nا‏ » هو مشابه لعملية حذفه (لكنه في الواقع موجود)› اذ لا يمكن 
استخراج البيانات من أو مشاهدته عند استخدام مر .DESCRIBE‏ 

استخدام أ٘مر ۸L۲ ER TABLE‏ لحذف ہہصںاہC‏ ۰ یسمح فقط بحذف رہصںاہC‏ واحدۃ کل مرة› ولکن 
باستخدام ٠ UN S٤3‏ يمكن وضع أكثر من رص ں اه٥‏ في هذه الحالة ثم حذفها جميعا في نفس الوقت. 
يجب إضافة جل CASCADE CONSTR۸AIN1S‏ اذا کانù Foreign key ةقاle Column Jd‏ مچ 
Column‏ آخر. 


ملاحظة. يحب على الأقل أن یبقی nرصuاه€‏ واحد في ال اه٣‏ بعد الحذف وإلا لن تنجح عملية الحذف › 
ولا يمكن استرجاع ال رص_ں1ه) المحذوف بعد حذفه. 
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مثال تطبيقي 79 
لحذف ,رہ ںاہ٥C‏ بشکل مباشر: 


ALTER TABLE HR.TEST 
DROP COLUMN LAST CASCADE CONSTRAINTS; 


في حالة ال «ںاه٥‏ الذي يحوي بيانات كبيرة » وتوقفت عملية الحذف قبل حذف ال مص ںاه٥‏ يمكن كتابة: 


ALTER TABLE HR.TEST 
DROP COLUMNS CONTINUE; 


:UNUSED ll في‎ Column وضع ال‎ 


ALTER TABLE HR.EMPLOYEES 
SET UNUSED COLUMN PHONE_NUMBER CASCADE CONSTRAINTS; 


:Unused Columns Û أحذف‎ 


ALTER TABLE HR.EMPLOYEES 
DROP UNUSED COEUOMNS; 


:OUERYING TABLE INFORMATION 


لمعرفة ال وص ںاہ used‏ ما في ال 11e‏ یستخدم : 


:DBA_UNUSED_COL_ TABS °‏ يوغر معلومات/حو لاال sمص_ں1ه٥‏ الموضوعة في حالة 
UNUSED‏ » و اسم ال م۲41 واسم المستخدم المالك لل ۲[(ه1. 


للحصول على معلومات حول ال وماطه] يمكن استخدام: 


:D(B A_1 ABLES °‏ یوفر معلومات عدیدة مثل اسم ال 1۲ا۲۹ واسم ال ع٥‏ م٥1ط‏ ه۲ التي تنتمي 
لها ال م1ط ه١‏ و اسم المستخدم الذي يملك ال ۲1٥‏ وخواص ال S٥۲4٥‏ (مثل [غUSEا )°P٤٥1‏ 
و غیرها. 

. ۹1۲ من ضمنھا ال‎ "0طز٥‎ c٤" یوفر معلومات حول جمیع العناصر‎ :D(B۸_ OBJECTS 
من المعلومات المتوفرة اسم العنصر و توقيت تكوينه و الحالة التي هو عليها و غيرها من‎ 
المعلومات.‎ 


للحصول على معلومات حول ال sرصں‌اهC‏ في ال 1۲ط ۲4 یمکن استخدام: 
:DB A_۲ ۸B_ COLUMNS °‏ یوفر معلومات عدیدۃة مثل اسم ال 1eطا‏ ھ٣‏ واسم ال Column‏ 


وخواص ال ۲ہ ںاه٥‏ وغیرھا. 


ملاحظة: كما يوجد view‏ بام D(8BA_7 ۸ BLES‏ ıوجد‏ ايض USER_TABLES‏ 
۸L1 "ABLESg‏ . تذکر اقسام ال وس۷1 راه« )ء1( في الفصل الثالث. 
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MANAGING INDEXES 


ساعد ال ٥×‏ "1 في تسریع استخراج البیانات من ال 6s[ط‏ ھ۲ كما يخفف من اڵ Input/Output‏ 
الناتج عن ال وعiإمں‏ (لأنه يمنع حدوث بحث كامل على ال م[ط ه٠‏ للحصول على البيانات). يوجد 
خواص مشترکة بین ال 1۲ا۲۹ و ال چم لہ[ء حیث کما أنه یمکن تکوین ٥1ا۲۸ ۴۹۲٤٤٥۸٥4‏ یمکن 
أيضاً تکوين ›Partitioned 1n e×‏ ايضاً يوجد Storage Parameters‏ لل dex‏ ہ1 مشابه لل 
.Table Jİ Storage Parameters‏ 

يمکن أن يتم تكوين ال ×م لم[ ل مص ں1٥٥‏ واحد فقط ويسمى في هذه الحالة >مdم]‏ ماعمذ؟ »› كما 
یمکن تکوین ال 1,۵٥‏ لیشمل أکثر من رصں اه٥‏ (الحد الأقصی ورصں‌اه٤‏ 32 ) ويسمى في هذه 
الحالة [nd e>‏ مtزومم0m).‏ لا يوجد حد لعدد ال و»×م 1.4 التي يمكن تكوينها على ال »1ا11 › ويتم 
ادارة ال dex‏ ہ1[ من قبJ .Oracle Server J|‏ 


من أنواع ال × dم]:‏ 


:UN]QUE INDEX °‏ یمکن تکوین هذه النوع لضمان عدم وجود بیانات متشابه في ال R0۷Ws‏ 
ضمن ال رہ ں!1ه٤‏ الذي تم تکوین ٥×‏ !] علیه. 

:NON-UN[QUE INDEX‏ یسمح هذه النوع بتشابه بیانات ال 8٥۷s‏ في ال !ه٤‏ الذي 
تم تکوین لم1 علیه. 

:۴UNC]]0N-BASED INDEX °‏ يمكن تكوين هذا النوع لتسريع استخراج البيانات من ال 
85سا التي تحتوي علئرعطلیات مختلفة"وږ من)مرں ۴" مثل استخدام ال 18 9708S‏ أو 
NSTR‏ |[ أو "REPLACE‏ أو غیھا في ال .€01u mn‏ 

:PARTITI[ONED INDEX °‏ تم تکوین أكثر من ]N5 ٤×‏ في أکثر من ٥۲‏ ع8 في 
ءاه" مختلفة. يستخدم لل"وم]136 التي تحوي بيانات كبيرة جداً وغالباً ما يستخدم لل 
.Partitioned Tables‏ 


.Bitmap Index ys B-Tree fh dex lak اعتماداً على نموذجين‎ [n> يمکن أن يتم تکوين ال‎ 


:B-TREE INDEX 


التكوين الداخلى لل مم1 يكون على شكل شجرة لها أصل وفروع. تتكون الشجرة من ثلاثة أجزاء هي ال 
Rt‏ المتصل بال وءطءم ه8 المتصلة بال fsهم.]‏ التي تحتوي على ال [4٥× ٤٤٥s‏ التي تشير أو 
تدل على ال s‏ سه8 في ال ٥1ط‏ ۲۹ باستخدام ال ء٤ءز W15s‏ ۸0 . في الرسم 7.1 يدل الرقم 1 على ال 
Rot‏ » الرقم 2 علی ال ط٤۸‏ ھ8۲ والرقم 3 علی ال fھوم.‏ 


يتکون کل ال ر٤۴‏ ×14 من أربعة أجزاء هي: 


EADERګH:‏ یتم تخزین فیه عدد ال ومصںاه٥‏ التي تعتمد على نوع Single, ) Index Û‏ 
.(Composite‏ 

0L0 MN LENGTH °‏ : الذي یحدد حجم ال رص .C٥01u‏ 

.C01u n الذي یحدد قیمة ال‎ : 0L0 MN ۷ALUE 

. ۲۹1۲ في ال‎ 80s الخاصة بال‎ ۴0W 15s أرقام ال‎ :NROWID 
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TABLE'S ROWS 
7.1 رسم‎ 


ملاحظات : 


1 عندما یحدث عملیة ]NSE R1‏ ل170 یقوم الأوراکل باضافة [nd e× Ey‏ جدید لیمثل ال R0 Ws‏ 
الجديدة المضافة. 

2- لا يمكن الإستفادة من 8-1۲٠۲ 1]. ٥×‏ فلي ال وس٠8‏ التي تحوي على ل ". أي عند البحث بواسطة 
جل WHERE‏ عن قيمة )where اas_ namê z null) NULL‏ فإن الأوراکل یقوم باجراء بحث کامل 
على ال م۲41 ولا يقوم باستخدام ال چهلم1. 

3- يفضل استخدامها على ال «ص_ںآه٤‏ الذي يحوي بيانات مختلفة (مميزة) كبيرة مثل أرقام الهاتف 
وعناوين الموظفين . 

4- لا يفضل استخدامها على ال ومدص سںاه) التي تتعرض لجملة ال 0R‏ بشكل مستمر. 


:BITMAP INDEX 


التکوین الداخلی لل [٥×‏ یشبه تکوین ال 8-1۲٠۲‏ عدا عن استخدام W15s‏ ۸0 يتم استخدام خريطة 
بایتات "8)4" لتحدید ال سه8 في ال ٦۹1٥‏ بحیث یمثل کل بایت ۸0٥١ W۷ 1D‏ . 


ملاحظات: 


1- یفضل استخدامها على ال «صںآه) الذي لا یحدث لبیاناته تجدید مستمر )٥'"‏ ھلما 0Wا"'.‏ 

2 يفضل استخدامھا عند استخدام WHERE‏ أو 0R‏ بشکل متکرر. 

3 يفضل استخدامها على ال ٥1ط‏ ه٠‏ التي تحوي بيانات كبيرة جداً ونسبة البيانات المختلفة (المميزة) فليل 
جداً مثل نوع الإنسان (ذكر أو انثى). 

4- عندما یحدث تغییر لبیانات ال رص ں‌اه٤»‏ يتم تجديد ال مه ")81 لتناسب التغيير. 
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:CREATING B-TREE INDEXES 
قبل تکوین ال ×ملم] ينصح بالتالي:‎ 


تكوين أقل عدد ممكن من ال و»×٥‏ لم[ على م1طه1 تجري عليها عمليات D11‏ كثيرة» لأن ال 
»ع14 يبطئ هذا النوع من العمليات. 


ه وضع ال sم×مل‏ م[ في aceمءء1ط14‏ خاصة. 

۰ اختیار 61×6 N٥106‏ لل de×esہ][‏ الکبیرة. 

ه قيمة العامل ۸۸8 ]N]۲۸‏ يجب أن تكون أكبر من مثيلتها التي حددت على ال 1۲طه٣.‏ 
لتكوين × لہ[ 8-1۲٠۲‏ يجب اتباع القاعدة التالية: 


CREATE [UNIQUE] INDEX index name 

ON [schema.[]TABLE (Column [ASC | DESC] , Column [ASC|DESC] , ...) 
[TABLESPACE tablespace_name] 

[PCTFREE number] 

[MAXTRANS number] 

[MINTRANS number] 

[LOGGING | NOLOGGING] 

[NOSORT] 

[STORAGE INITIAL number K|M NEXT number K|M .....] 


فی القاعدة: 
:٣۲۴R EE ٠‏ هي المساحة التي تحجز في كل )8106 عند تكوين ال × م[ لكي تستقبل ال 
م [n4‏ الجديدة. 
N0508‏ : تحدد أن ال 8٠۷s‏ مرتبة بالترتيب التصاعدي وبالتالي لا يجب على ال ماع0 
Serve‏ ترتیب ال R٥ ۷W‏ عند تکوین ال ×deہ1.‏ 
:AS€C|][(E٥ ۰‏ تحدید اذا ما کان علی ال ©۲4٤1 Sم ver‏ تکوین ال 1٥×‏ بشكل تصاعدي أو 
تنازلي. 


ملاحظة: لا یمکن تحدید ال P٤٥۲0 S٤D‏ لل .]nde×‏ 


:7.10 مثال تطبيقي‎ 
:B-Tree Non-Unique Index ùıgكت‎ 
CREATE INDEX ind HR test 
ON HR.TEST (FIRST) 
PCTFREE 30 
STORAGE (INITIAL 200K NEXT 200K PCTINCREASE 0 MAXEXTENTS 50) 
TABLESPACE INDX; 


لتکوين B-T ree Unique Index‏ أضف كلم UNIQUE‏ ب±= CREATE‏ مباشرة. 
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:CREATING BITMAP INDEXES 


لتكوين ٥×‏ لہ[ 812p‏ يجب إضافة كلمة 8B]۲ M4۲‏ الى جملة CREATE ]ND EX‏ التي تم 
استخدامها في المثال 7.10. يمكن تحديد الحجم المخصص من الذاكرة لتخزين الموص.)8 بتحديد 
العامل CREA E_ BITMAP _ AREA SIZE‏ الذي قيمته في الحالة u [٤‏ ء0 هو .8M8‏ 
بزيادة حجم قيمة العامل» يتم تكوين ال >"1 بسرعة أكبر» ولكن ينصح باستخدام قيمة صغيرة اذا كانت 
البيانات المميزة (المختلفة) في ال مص داه قليلة جداً (بيانات مختلفة كبيرة = ذاكرة كبيرة). 


مثال تطبيقي 7.11: 


CREATE BITMAP INDEX ind HR _jobid 
ON HR.JOBS (JOB_ID) 
PCTFREE 30 
STORAGE (INITIAL 200K NEXT 200K PCTINCREASE 0 MAXEXTENTS 50) 
TABLESPACE INDX; 


مثال تطبيقي 7.12: 
يمکن تکوين re٤ [dex‏ 8-1 أو Bitm 4p ]ndex‏ عبر ال م1امومه باتباع الخطوات التالية: 


Standalone عڊر‎ Console Û ادخل الى‎ 

اضغط على اسم ال مء طه)ه0 لكي تظهر نافذةاتظلي من.اسم المستخدم و كلمة السر. 

أدخل اسم المستخدم وكلمة السر مع التاكد من اختياً84 S۷55‏ عوضاً عن إوصإه.. 

.Schema Manager J| + اضغط على‎ 

اضغط على مجلد [1٥×‏ ثم بواسطة الزر اليمين للفأرة(الختر من القائمة ٠٤و٠إC٤.‏ 

ادخل اسم ال ٥ہ[‏ وأختر ال 4ر٥‏ طءS؟‏ و ال ce‏ ےم ء٤۲۹61‏ من القوائم › ثم اختر ال Cum‏ 

أو ال ورہںاہC‏ المراد وضع ×deہ]‏ لھا من ائم .Table Columns‏ 

٠ه‏ لتكوين ءلم[ مو_B1‏ » ضع علامة داخل المربع الصغير (فوق زر ٠٤4٠إ))‏ بجانب كلمة 
.Bitmap‏ 

ه أختر باقي البيانات من القوائم الأخرى (Storage, Partitions, Options)‏ 

اضغط علی زر .٤۲٥4)٥‏ 


119 


:ALTERING INDEXES 


يمكن القيام بعدة مھمات باستخدام جم :ALTER INDEX‏ 


:Changing the Block Storage Parameters 


یمکن تغییر قیم بعض العوامل مثّل ۸۸8 1۸×1۸ ويمكن تغيير بعض عوامل جملة ال #عوإه)؟ مثل ال 
.MAXEXTENTS‏ 


مثال تطبيقي 7.13: 


ALTER INDEX ind HR _jobid 
MAXTRANS 250 
STORAGE (MAXEXTENTS 200); 


أو عبر ال م1مو ه٥‏ باتباع الخطوات التالية: 


.Sta n da167 êڻبع‎ °0 1501e ادخل الى ال‎ 

اضغط على اسم ال #ءوطهه((لكي.تظهر نافذة تطلب من اسم المستخدم و كلمة السر. 

أدخل اسم المستخدم وكلمة السر مع(إلتاكد من اختيار 84 S۷505‏ عوضاً عن إوإإه.. 

„Schema Manager J| + اضغط على‎ 

اضغط علی + ال ×deہ[.‏ 

اختر اسم المستخدم الذي يملك ال ×ء 1,4 المرادتغيير خواصها (مثل ۸ ) 

اختر اسم ال ل1 من النافذة اليمنى و اضغط ليها مزثين (أو بواسطة الزر اليمين للفأرة › اختر 
من القlئمة ."View\Edit Details"‏ 

.# ادخل الى قائمة ءعهإهم)S » وعدل البيانات ثم اختر رارم‎ ٠ 


:Allocating & Deallocating Extents 
1هط[e يمكن اضافة وا٤ )× الى مساحة ال >م لم[ بنفس الطريقة المستخدمة في إضافة )٥)×ع الى ال‎ 
بنفس الشروط. كما يمكن حذف وار م)»×E فارغة غير مستخدمة من مساحة ال هل.1 بتعويض جملة ال‎ 
بالجملة التالية:‎ ۸ LL[0CATE EXTENT 

DEALLOCATE UNUSED [KEEP number [K|M]] 
في القاعدة:‎ 


.Unused Extents J| لإبقاء مساحة خالية من‎ KEEP 
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مثال تطبيقي 7.14: 
لإضاغة Extent‏ : 


ALTER INDEX ind HR _jobid 
ALLOCATE EXTENT SIZE 200K; 


لحذف مساحة خالية (و٤ر٤)x٤):‏ 


ALTER INDEX ind_HR jobid 
DEALLOCATE UNUSED; 


:Rebuilding Indexes 


لنقل ال ٥×‏ لہ[ الی c٥‏ ےمی٥1ط‏ ۲۹ آخری أو لتغییر خواص ال $٥۲۸ ۴۸۲4٥٤٤٥۲۶‏ یمکن استخدام 
REBUILD ge ALTER INDEX‏ كما توضح القاعدة: 


ALTER INDEX [schema.]Index name REBUILD 
[TABLESPACE tablespace_name] 

[PCTFREE number] 

[INITRANS number] 

[MAXTRANS number] 

[LOGGING | NOLOGGING] 

[REVERSE | NOREVERSE] 

[STORAGE (INITIAL SIZE [K|M] NEXT SIZE [KIM] ....] 


في القاعدة: 
:REVERSE ®‏ يمکن تحویل ال ×11 الى نوع Reverse ey [n>‏ باضافة الجملة الى 
القاعدة. هذا النوع يعرف بيانات ال مصں‌اه٥‏ بشکل عکسي » مئل لو کان 0۲۵۲_15 يحتوي 
على الرقم 12345 فإن الأوراكل يعكس الرقم الى 54321 ویضیف ال رص ںاہ الى ال .[,de×‏ 
هذا النوع بستخدم بالعادة مع ال ووصںآه المعرفة بياناتها بشكل تصاعدي» اذ يتم توزيع البيانات 
المتقاربة الى ئfهم.]‏ مختلفة ليتم تسهيل أخراج البيانات بسرعة أكبر. 
نتائج عملي Rebuild Index J|‏ : 
ه بعد انتهاء العلميةء يتم تكوين ٥×‏ ل1 جديد و حذف الأصلي» بحيث تساعد على تكوين ٠×‏ 1,0 جديد 
متكامل غير ال ×14[ الأصلي الذي قد يكون قد فقد جزء من مساحة نتيجة للتغيرات التي تطراً على 
ال Rs‏ مثل حذف البیانات و تجدید ها "٥,٤2 ٤10,(‏ عه۴۲) › وبالتالي استخدام وتخصیص 
المساحة بشكل أفضل. 
ه خلال العملية › يمكن لل وعمںQ‏ استخدام ال مم[ الأصلي. 


ملاحظة: لا یمکن استخدام 11ں ط8 لتغییر ال یلم1 من 8-1۲۲ الى موص)81 أو بالعكس. 
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مثال تطبيقي 7.15: 
للقيام بعميلة 1ز طءR‏ على ال ×هdم]1:‏ 


ALTER INDEX ind HR Jobid REBUILD 
TABLESPACE INDX02; 


Rebuilding ONLINE 

أحياناً تستهلك عملية 114 طءR‏ وقت كبير جداً عندما تكون ال ٥1ط‏ ه٣‏ كبيرة جداً. في السابق لم يكن بالمقدور 
القيام بمهمات ال M11‏ على ال ماطهآ التي يجري عملية >ملم] dازuطءR‏ على xمdم1‏ مخصصة لها. 
في النسخ الحديثة من أوراكل (81٥1ءهإ0‏ و 91٥1ءهإ0)‏ يمكن أن تجري مهمات ال ]۷[ بينما تتم عملية 
Rebuild Index‏ بإضافة ٤INEاON‏ الی جانب ۰R E811‏ ولکن لا ینصح بالقیام بمھمات کبیرة 
ويفضل الاقتصار على المهمات الصغيرة. 


ملاحظة: لا يسمح بكل الأحوال القيام بمهمات ال 551 على ال 1eط1ab‏ خلال .Rebuild Index ÛI‏ 


:7.16 مثال تطبيقي‎ 
?Tîn dex JI عل‎ Rebuild Online للقیام بعميلة‎ 


ALTER INDEXıiind HR Jobid REBUILD ONLINE; 


:Coalescing Indexes 
.1مdه× بالقيام بعملية ءءم[aوهC٤ على ال‎ [4٥× یه۴ في ال‎ ٤:٤٤10 يمكن التخلص من أثار ال‎ 
ع۴۲۹ فأصبحت کل‎ ٥,٤4٤1٥٣۸ کما يبدو في الرسم ۰7.2 وجود 2 ھم[ تعرضتا لعملیات ادت الی حدوث‎ 


واحد منهما نصف ممتلئة. ولكن بعد حودث مءءء[وه٥)‏ تم دمج النصفين مع بعضهما مما نتج عن وجود 
1۴ فارغة تماما. 


و 


رسم 7.2 
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مثال تطبيقي 7.17: 
للقيام بعملية ۽ر¡041¢sc٥‏ لل :Index‏ 


ALTER INDEX HR.ind hr _ jobid COALESCE; 


:Identify Unused Indexes 


یمکن وضع ×ملہ] تحت المراقبة لمعرفة اذا کان یستخدم م ل وبالتالي حذفه في حال عدم استخدامه. یتم 
جمع المعلومات حول ال ×ع 4 د1 المراقب في .V$OBJECT_ USAGE‏ 


ملاحظة: كل مرة يتم فيها مراقبة ال ×ملم!] › يتم إلغاء البيانات السابقة لل مم1 في 
.VŞOBJECT_ USAGE Û‏ 
مثال تطبيقي 7.18: 
لوضع ال ×م لم[ تحت المراقبة: 
ALTER INDEX HR.ind_ hr jobid MONITORING USAGE;‏ 
لوقف مراقبة ال م dم]:‏ 


ALTER INDEX HR.h hf jobid NOMONITORING USAGE; 


:ANALYZING INDEXES 
للقیام:‎ ۸N۸ 1Y 7Z€ ]N 5٤× یمکن استخدام جملۀ‎ 


٠ه‏ التأكد من أن ال وم81 الخاصة بال >م لم[ لا تحتوي على بيانات فاسدة " )0ا8 
.""Corruption‏ 


٠‏ للحصول على معلومات حول ال ×مأم[. 


بعد القیام ب ٤×‏ 15 ٤1۷7۴ا۸N۸‏ یتم تخزین معلومات حول ال مل[ في س۷1 اسمهھ 

NDEX_ STATS‏ | › یعرض هذا ال ۷1W‏ معلومات عن عدد ال وع ٥ا8‏ وعدد ال وkعم81‏ المستخدم 
ولكن أهم من ذلك هو رقمي كل من 80⁄١ WS‏ ۴|[ و DEL LF R0١ W8‏ ۰ بحیث اذا زادت النسبة بین 
الرقمين عن 30% (مثلاً الرقم الأول يساوي 50 والثاني يساوي 100 فهذا يعني النسبة %50) فهذا يعني 
أن ال xم‏ ہ1 تعرض لحذف بیانات "R٥ Ws"‏ کثیرة مما قد ینتجھ عن ٤1٥۸‏ ٤۸ہ‏ عھا۴ في ال ×deہ1.‏ 
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مثال تطبيقي 7.19: 
للقيام بعملية yze[ھ‏ م۸ لل ×eل1]n:‏ 

ANALYZE INDEX HR.JOB_ID_PK VALIDATE STRUCTURE; 
:1N(5٤×X_ $1۸18 بعد ذلك استخرج المعلومات من‎ 


SELECT BLOCKS , PCT USED, LF_ROWS, DEL LF ROWS 
FROM INDEX STATS; 


يظهر في جهازي الناتج التالي: 
BLOCKS PCT USED LF ROWS DEL LF ROWS‏ 


0 19 9 16 


وكما تلاحظ النسبة بين الرقمين لا تتجاوز ال 30%. 


:DROPPING INDEXES 


عند عدم الحاجة لل ×م لم[ أو عند حدوث خلل له أو عند تحول حالة ال ×م م1 الى N۷۸15‏ بسبب 
حدوث خلل لل مeم‏ ووم[ › یمکن حذف ال de>‏ 1[ بواسطة جlaة .DROP INDEX‏ 


ملاحظة: لا یمکن حذف ال e>‏ لہ[ اذا کان Unique KÊY Primary Key‏ ولديە علاقة مغ .FK‏ 


مثال تطبيقي 7.20: 
لحذف ×deہ[آ:‏ 

DROP INDEX hr.ind hr jobid; 
أو عبر ال م1مو ه٥ باتباع الخطوات التالية:‎ 


ادخل الى ال s01¢ئCon‏ عڊڙر .Standalone‏ 

اضغط على اسم ال مووطه)ه لكي تظهر نافذة تطلب من اسم المستخدم و كلمة السر. 
أدخل اسم المستخدم وكلمة السر مع التاكد من اختيار S۷S584‏ عوضاً عن إومإه.. 
اضغط على + .Schema Manager J|‏ 

اضغط على + ال .]"۵٥×‏ 

اختر اسم المستخدم الذي يملك ال ×مإم!] المراد حذفه (مثل )§R‏ 

اختر اسم ال 1٥×‏ من النافذة اليمنى و بواسطة الزر اليمين للفأرة › اختر من القائمة 
("Remove"‏ أو من القائمة الأساسية› .Remove pۃ؟û Objec†‏ 

اختر ی۷6. 
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:QUERYING INDEX INFORMATION 
للحصول على معلومات حول ال ×ع ل[ يمكن استخدام:‎ 


:DBA_]NDEXES °‏ يوفر معلومات عديدة مثل اسم ال ×[ ونوعه واسم ال 1۲ ط۹٣‏ التي 
ينتمي لها ال ×م 11 واسم المستخدم الذي يملك ال لم1 وخواص ال #عه4١٥5)0‏ وغيرها. 


:DBA_]ND_COLUMNS °‏ یوفر معلومات عدیدة مثل اسم ال ex‏ لہ[ واسم ال °01 
التي وضع عليها ال ×م ل1 وخواص ال مص ں1٥٥‏ وغیرها. 


.Function-Based Indexes J| J> ڍر لومت‎ :DBA_IND_EXPRESSIONS 
يوفر معلومات ناتجة عن عملية ×م لم[ چ«ذاەtن«10[. يوفر‎ : $0 BJ EC_USAGE 
لم] واذا ما کان‎ ٥× التي ينتمي لھا ال‎ ٣٣ ط1٥ معلومات حول مثل اسم ال ×[ ونوعه واسم ال‎ 


یحری عملیة چرذه†¡ M0‏ علی ال × ۵ہ[ ام لا ( 05٤5‏ التي تدل علی اذا ما کان تم استخدام 
ال مم1 خلال المراقبة )» وقت بداية وانتهاء المراقبة "عمiاهMonİit".‏ 
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MANAGING CONSTRAINTS 


يمكن وضع قوانين على ال )د5 (مثلاً عدم السماح بوجود بیانات متشابه في ٣ہ‏ ں[٥٤)»‏ باستخدام کل من 
.Integrity Constraints s «+ Database Triggers + Application Code‏ 

ال Application Code‏ عبارة عن برمجة كود محدد (مثل برمجة الجافا) يعمل كبرنامج لوحده في ال 
C1ient‏ أو من ضمن ال 4۲ط وھ( علی شکل .۴۲٥ ٤٤4 ue‏ اما ال Database ۲ r1gges‏ فهي برامج 
من تكوين [@ ۲1/8 › يتم تنفيذها عند حدوث مهمة محددة في ال موو طه)ه( مثل القیام ب 1S٤‏ أو 
UPDATE‏ . 


:INTEGRITY CONSTRAINTS 


يفضل استخدام هذا النوع عن النوعيين الأخريين لسهولة تكوينه وتعديله › ولسهولة تشغيله أو وقف تشغيلهء 
ولإمكانية استخراج معلومات عنه من ال راو" ٠ا51‏ و0at.‏ يوجد عدة أنواع من Integrity J|‏ 
Constraint‏ ھي: 


:NO1 NULL‏ يحدد أنه لا یمکن لل رص ں1ه٥‏ أن یحتوي علی (N01‏ کل ال 8٥ Ws‏ یجب أن 
:U€N]QUE‏ تحدد أن القیم الموجو 3ۃ فی ال مہ ںاہC(أو‏ آکثر من دہ ںاہ٤)‏ ممیزة ولا یمکن 
أن تتشابهء يستخدم هذا النوع عادق د تخصيص رقم مميز لكل موظف في الشركة. يسمح ال 
U} N]QU£‏ باستخدام قیم 1 ا N‏ في ال .R 0 ws‏ 

Primary Key Û! yk (Column ja )و أکأر‎ ColuînıîJÛا‎ jİ تد‎ :PRIMARY KEY 
في ال رہ ںuاہC وعدم‎ 8٥s في ال 1۲ط ۲. تکون مهمة ال ×۴ بضمان تم تشابه بیانات ال‎ 
.N" على قيمة 1ا‎ 80s إحتواء ال‎ 

FOREIGN KEY‏ : تحدد أن ال 01u نھارثکأ٣وأ( Colum‏ ) ھو Frei" Key‏ في ال 
rabe‏ › یتصل مع ۴ أو مںپ¡ € في ال ۲41e‏ أى في م۲41 أخری. 

:CHECK)‏ تحدد قانون یجب علی کل ال وس80 تنفيذه#(مثل أن يكون قيم ال 8٥s‏ الخاصة 
بجنس الإنسان» إما M1‏ أو ۴ › ولا يمكن ادخال أي بيانات#أخذى). 


:Integrity Constraints JI تٺںلlھ‎ 


يمكن وضع ال كخ«ذوإ٤وره٤‏ في أربع حالات تؤثر على البيانات المخزنة في ال م[اطه1 والبيانات الجديدة 
التي سوف يتم ادخالها مستقبلاً: 


:DISABLE NOVALIDATE‏ في حال وص Constraint Û‏ في هذه الحالةء لا يتم فحص 
البيانات الموجودة ولا يتم فحص البيانات المستقبلية لمعرفة اذا كانت تتطابق مع القانون أو الشرط 
الذي يحددo .Constraint J|‏ 

[SABLE ۷ ALIDA TE‏ : یتم ایقاف عمل ال ٤ہ‏ )یرہ٥٤‏ وحذف ال ×ع۵ہ] المخصص لھا 
وعدم السماح بالقيام بأي تعديلات على البيانات المخزنة (عدم السماح بعمليات .)0DM1‏ 
ENABLE NOVALIDATE‏ : لا يتم فحص البيانات المخزنة لمعرفة اذا ما كانت تتطابق مع 
قانون ال ٤٣ذ‏ )وره و لکن لا يسمح بادخال بيانات جديدة تتعارض مع ال "٤‏ ۲41)ء"هC€.‏ 
:ENABLE ۷ ALIDATE‏ يتم فحص البيانات الجديدة والبيانات المستقبلية والتأكد أنها تتطابق 
مع ال ٤ہذھاtوره).‏ في حال وجود بیانات لا تتطابق مع ال ٤ہ۲1٤ءہ٥)‏ فیجب حذفها أو تغيیرھا 


وإلا لا يمكن الدخول الى هذه الحالة. 
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ملاحظات: 

1- لا ينصح التحويل من الحالة الأولى أو الثانية مباشرة الى الحالة الرابعة › اذ أن ذلك يؤدي الى عمل 
0cksا‏ علی کل ال اھ۲ مما قد يؤدي الى تأخر انجاز مهمات ال 0[11/ لذلك ينصح بالتحويل الى حالة 
Enable Novalidate‏ أو قبل التحويJ .Enable Validate Û‏ 


2- عندما یتم تحویل Cons) a1٤‏ تستخدم Primary Key‏ أو Unique Key‏ من حالة eاEnab‏ الى 
حالة ماهو » فان ال ×م 1.0 الموجود يتم حذفه والعكس صحيح. 


3- التحول من حالة Enable Novalid ate‏ الى حالة Enable Validate‏ › ¥ يوقف عملیات ال .D551‏ 


:CONSTRAINTS CHECKING 


يمكن لل s٤رذوإ٤وره)‏ أن يقوم بفحص البيانات المدخلة الى ال ماطه إما عند نهاية كل مهمة من مهمات 
ال DM1‏ و يسمی في هذہ الحالة Non deferred‏ أو ]mmediate‏ › أو يمكن لل s)م1ھاstر C0‏ أن يقوم 
بفحص البيانات عند كتابة اصإه) (قد يشمل مجموعة من المهمات) ويسمى في هذه الحالة أ١٠۲إءfء0›‏ 
في كلتا الحالتين يتم عمل و ط11ه 8R‏ للمهمات التي انجزت اذا لم تتوافق مع قانون ال ٤"۲41)ء"هC€.‏ 
يفضل استخدام الحالة الثانية التي تنقسم الى قسمین بحيث تستطیع أن تشابه الحالة )!مء N0”‏ والحالة 
Deferred‏ معاًء القسسین هما: 

.Nondeferred ÛJI Jمعک تعمل‎ 1 N" ALLY IMMEDIATE 

.Deferred ÛJI قغمل کمل‎ NIT] ALLY DEFERRED ° 


لوضع ال ٤«ذدإ٤ءمه)‏ في احدى الحالتين يت استتتخدام القاعدة التالية: 
SET CONSTRAINT | CONSTRAINTS‏ 
(constraint _ name | ALL)‏ 
(IMMEDIATE | DEFERRED)‏ 
يمکن أيضاً استخدام 1ER SESS10۸‏ ۸ كما في القاعدة (تعمل في ال هزووم؟ المحدد فقط): 


ALTER SESSION 
SET CONSTRAINTS] = ([MMEDIATE | DEFERRED | DEFAULT) 


مثال تطبيقي 7.21: 
لتغيير حالة کل :Deferred Jl Constraints JI‏ 


SET CONSTRAINTS ALL DEFERRED; 
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:CREATING CONSTRAINTS 


يمکن تكوين ال .ALTER TABLE ûl gyi CREATE TABLE ةlaج مIدختساب Constr ain †s‏ 
يمكن تكوين ال )مها )وره في ال e۷e1[-«صuاهC‏ أو في ال امء۷٥.1-ء1ط14‏ على أن الأخيرة تسمح 
بتکوین ال "٤‏ ٤ه‏ لأکثر من ر" ں1٥٥‏ واحد وهذا لا تسمح به الأولى. 

يجب أن يكون للمستخدم REFERENCES Privilege‏ اللازمة لكي يستطيع تكوين وخم ذه۲٤یء«هC‏ في 
Shen‏ أخرى غير ال $1٥4‏ الخاص به. 


:Column-Level JI في‎ Constraints لتكوين‎ 


CREATE TABLE table_name 

(column _ name TYPE [CONSTRAINT constraint name] C1 | C2 | C3 | C4| C5) 
[NOT DEFERRABLE | DEFERRABLE [INITIALLY (IMMEDIATE | 
DEFERRED)] |] 

[DISABLE | ENABLE [VALIDATE | NOVALIDATE] 


أما ال °4 ,°3 ٤C1, ٤2,‏ فهي أنواع ال sئCons)raİnÉ:‏ 


[NOT] NULL =C1 

UNIQUE [USING INDEX ....] =C2 

PRIMARY.KEY [USING INDEX...] =C3 

REFERENCES [schema.] table name [(collnuf name)] [ON DELETE =C4 
CASCADE] 

CHECK (condition) =C5 


اما جملة US1N6 1ND ٤×‏ فھي تتطابق مع جملة CREATE 1N (٤%‏ عدا استخدام U S1N6‏ عوضاً 
peg «ON [schema.]TABLE (Colym/[ ASC | DESC] ءjجl دıحت pes CREATE jE‏ 
ذکر اسم ال ×deہ[.‏ 


في القاعدة: 


:0N DELETE CASCADE °‏ تضمن حذف البیانات المرتبطة في ال C114‏ بواسطة ۴K)‏ مع 
ال Parent‏ (راجع الأمتحان لٺJg .(Introduction to SQL‏ 


مثال تطبيقي 2.22: 
لتكوين Constraints‏ ي :Column-Level ÛI‏ 


CREATE TABLE hr.new_emp ( 

Emp_id NUMBER(8) CONSTRAINT new_emp_id pk PRIMARY KEY 
DEFERRABLE INITIALLY DEFERRED 

USING INDEX STORAGE (INITIAL 100K NEXT 100K) TABLESPACE indx, 
Emp_Name VARCHAR2(20) CONSTRAINT new_emp_name NOT NULL, 
Salary NUMBER(10) CONSTRAINT new_emp_ck CHECK (salary >0) 


J 
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:Table-Level] JI في‎ Constraints لتكوين‎ 


CREATE TABLE table_name 
(column_name TYPE , column name TYPE, ...., 


[CONSTRAINT constraint _ name] 

PRIMARY KEY (column_name , column name, ...) [USING INDEX ....] 

| UNIQUE (column _ name , column_name, ...) [USING INDEX ....] 

| REFERENCES [schema.] table_ name [(column_ name, column name, ...)] 
[ON DELETE CASCADE] 

| CHECK (condition) 


[NOT DEFERRABLE | DEFERRABLE [INITIALLY ([MMEDIATE | 
DEFERRED)] ] 

[DISABLE | ENABLE [VALIDATE | NOVALIDATE] 

J 


.Column-Level Û ف„‎ ¥! NOT NULE.Co straint ùيوكت ملاحظة: لا یمکن‎ 


مثال تطبيقي )6 
لتكوين Const‏ في :Table-Level] JI‏ 


CREATE TABLE hr.new_emp 

( 

Emp_id NUMBER(S) 

Dept_id NUMBER (8) 

Emp_Name VARCHAR2(20) CONSTRAINT new_emp_name NOT NULL, 
Dept_name VARCHAR2{20), 

Salary NUMBER(10), 

CONSTRAINT new_emp_id pk PRIMARY KEY (Emp_id, Dept id) 
DEFERRABLE 

USING INDEX STORAGE (INITIAL 200K NEXT 200K) TABLESPACE indx 
CONSTRAINT new_emp_ck CHECK (salary > 0) 

) 


ملاحظة: لتکوین ٤ہ1ه۲٤ءمهC٤‏ عبر ال م1امی,ه) اتبع خطوات تكوين ال م1ط ه٠‏ مع التأكد من ادخال 
البيانات في القائمة sاذaا†sىC0.‏ 


تذكر: يفضل توزيع ال وم×م ل[ الى عمacمءء1ط۲a‏ مختلفة عن ال e[ط14.‏ 
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:USING ALTER TABLE 


يمکن استخدام جملة LER TA BLE‏ ۸ لتکوین أو تعدیل حاlة .Constraints Û|‏ 


:Creating Constraints 


کما ذکرنا قبل قلیل أنه یمکن تکوین s٤ہ1ھ٣٤ء٬ C٥‏ باستخدام CREATE TABLE‏ أو باستخدام جملة 
۸L1" ER TABLE‏ كما في المثال 2.24. 


:2.24 مثال تطبيقي‎ 
:ALTER TABLE ةطmlgڊ‎ Constraints ةغlضإل‎ 
ALTER TABLE hr.new_emp ADD 
N new_emp_id_fk FOREIGN KEY (Dept_id) 


REFERENCES hr.departments (id) 
DEFERRABLE 


): 


لا يمكن تطبيق هذا المثال على ال 01 N01‏ ›» اذ يستخدم التالي لإضافة ٤مزوإء«ه٥‏ من هذا النوعء 
أو للتحويJ NULL sy NOT NULL ju‏ 


ALTER TABLE hr.new_emp MODIFY.Dept name NOT NULL; 


:Enabling Constraints 
.ALTER TABLE pIڍختwlڊ‎ Enable Jll Disable ja Constraint Û| يمکن تحویل حل‎ 
‘Enable No validate 


يفضل التحويل الى هذه الحالة أولاً قبل التحويل الى اllaÛة JI y Unique Constraints Jİ Validate‏ 
PK Constraints‏ لأن ذلك يؤدي الى عمل )م1 على كل ال ۲11۲ مما قد يؤدي الى تأخر انجاز 
مهمات ال ]¥[ مما يؤدي الى تأخر عملية التحويل. تستخدم القاعدة التالية للتحويل من حالة مء[طدء5 
ئ .Enable Novalidate ll‏ 


ALTER TABLE [schema.] table_name 

ENABLE NOVALIDATE {CONSTRAINT constraint name | PRIMARY KEY | 
UNIQUE (column , column2, ....) } 

[USING INDEX.....] 


بحيث يتم اضافة جملة 1N( ٤×‏ S1N6ا‏ في الحلات التي یتم فیھا تحویل حالة ال ٤ہ¡ P× Cons)‏ أو 


ال €ni ue Constraint‏ فقط ويحب أن تكون الحالة التي تم تكوينهم في البداية اه٣‏ مء( ويجب أن 
يكون ال هل .[ الذي تم تكوينه في البداية إما ل٥ء1طهوا‏ أو تم حذفه. 
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-Lnable Validate 


هي الحالة الإفتراضية "٤[ں‏ وء(" التي يتم فيها التحويل من ال م1ط هوا الى ال ماه" .٤‏ بعد عملية 
التحويل يتم فيها وضع ].0cks‏ علی البيانات حتى تنتهي عملية فحص البيانات الموجودة» وفي حالة عدم 
وجوذ PK, UNIQUE Constraints ÛÛ [Indexes‏ » يقوم ال Server‏ eاOrac‏ بتکوین ×deہ]‏ من نوع 
Non-U nique‏ اذا کان قد تم تکوین ال s٤مذهوم‏ ه٥‏ في البداية بالحالة 1۲ ه٣إ٠۴ء(‏ والعكس صحيح اذ 
یقوم ال Orac1e Server‏ بتکوین e×‏ لہ[ من نوع ue‏ 1ہ ا اذا کان قد تم تکوین ال sمذھاtووه٥‏ في 
البداية بllÛة .Nondeferrable‏ 


تستخدم ذات القاعدة التي تستخدم للتحويل من حالة 1ط aوء1(‏ الى حالة Enable Novalida†e‏ مع استبدال 
Validate) A LIDATE ûn NOVALIDATE nl‏ هي ال {اDefau)‏ وإمكانية إضافة جملة 
٤۴× CEP [58‏ التي سوف نتطرق لھا بعد قلیل. 


مثال تطبيقي 2.25: 
لتحويل الحالة الى :N0va11d ate‏ 


ALTER TABLE hr.new_emp 
ENABLE NOVALIDATE CONSTRAINT new_eînp_id_pk; 


لتحويل الحالة الى ع٤‏ لiاو۷:‏ 


ALTER TABLE hr.new_emp 
ENABLE VALIDATE CONSTRAINT new emp_id_pk; 


لتحويل الحالة باستخدام ال e[مورهC:‏ 


ادخل الى ال C001‏ عیبر .Standalone‏ 

اضغط على اسم ال مءطهه( لكي تظهر نافذة تطلب من اسبم المستخدم و كلمة السر. 

أدخل اسم المستخدم وكلمة السر مع التاکد من اختيار 6۸ S۷55‏ عوضاً عن إوصإه.. 

.Schema Manager J| + اضغط على‎ 

اضغط على + ال .٣(1۲‏ 

اختر اسم المستخدم الذي يملك ال ٥1ط‏ ه۲ المراد تغيير خواصها (مثل #۸) 

اختر اسم ال م1ط ۲1 من النافذة اليمنى و اضغط عليها مرتين (أو بواسطة الزر اليمين للفأرة › اختر 
من القlئمة ."View\Edit Details"‏ 

٠‏ ادخل الى قائمة و٤مذھاtیره٤‏ › ثم عدل البیانات ثم اختر رامم۸. 
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:USING EXCEPTIONS 


تستخدم جملة ال ۲۲108 5×۳٤‏ لمعرفة البيانات التي تخالف ال و٤رذوإ٤ورهC‏ بعرض معلومات حول 
ال البيانات "R0 ws"‏ المخالفة لل Constraint‏ في .EXCEPTIONS Table Jaصت Table‏ 


للقيام بفحص البيانات قبل القیام بتحویل ال ٤1۸و٣)ءمه٥‏ من حالة ٥1ط‏ 4و1( الى مهمع يمكن اتباع 
الخطوات التالية: 


تکوین ال ٥1ا۹٣‏ ء«منامpمExc ١‏ اذا لم یتم تکوینها من قبل بتشغیل S٤‏ هو 41ء.٤م1e×c)»‏ 
من داخل ال 85ا٥۲ :58Q‏ 


@ C:\oracle\lora90\rdbms\admin\utlexcpt.s ql 


تحویل ال Const a1)‏ الى Enable Validate‏ بإضافة الجملة التالية اى ALTER‏ 
:TABLE‏ 


EXCEPTIONS INTO system.exceptions 


ه في حال ظهور اخطاء تمنع من تحویل حالة ال Conta‏ الى Enable Validate‏ استخدم 
المعلومات التي تكونت في ال ٥1ا4٦‏ ٤ہہ‌نامExcep.‏ 


SELECT * FROM taþblıfame 
WHERE ROWID IN (SELECT ROW “ID FROM EXCEPTIONS); 


„UPDATE TABÎF ط¦bسl اجراء تعديل للبيانات المخالفة بو‎ ٠ 


.ALTER TABLE plıڊتwlî‎ Enable Validate Jll Constraint J| Jug 


:OUERYING CONSTRAINTS INFORMA TION 
للحصول على معلومات حول ال s٤م1ھا )یره يمكن استخدام:‎ 


:D(BA_)C0NSTRAINTS‏ يوفر معلومات عدیدة مثل اسم ال "4ء" ونوعه والحالة 
التي يوجد فيها وغيرها من المعلومات. 


:D(BA_C0NS_COLUMNS °‏ یوفر معلومات عدیدة حول ال ود ں1٥٥‏ التي وضع علیھا ال 
.Constraints‏ 
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اذہل الثامم 


إدارة! البو ززز و باسورد 
سیصضور ني و الریسور سيس 


Managing USERS & password 
SECURITY& RESOURCES 


PASSWORD MANAGEMENT 


:PROFILES 


یستخدم ال ع[زگ م٥‏ للتحکم بال od‏ wییھ۴‏ وال ۶٥ں‏ ٥ء٥8‏ بواسطة ال 8۸( عبر تحدید عوامل 
"Parameters"‏ خاصة بال 1اه ۴› من الأمور التي يمكن التحكم بها مثلاً أن يمنع بعض المستخدمين من 
اجراء مهمات محددة أو إخراج المستخدم من اÛ Database‏ اذا لم ینفذ مهمات لوقت محدد. عند تکوين ال 
Database‏ › يقوم ال Sever‏ eاOrac‏ بتکوین ال ٥11گ u[٤ ۴۲٥‏ هه الذي يخصص لجميع المستخدمين ما 
لم یتم تکوین ۴٥۴11٥‏ جدید(کل القیم في ال ۴0۴11٥‏ ٤اںهfء‏ 0 تساوي 4٥)نصذاہ€).‏ یمکن آن یخصص 
"Assign"‏ ال eاProfi‏ لل Users‏ فقط ولا یمکن تخصیصہ لل R٥1٥‏ أو ۴٣٥1٥‏ أخریء ولا یؤثر 
تخصیص ال ۴۲٠۴11٥‏ على ال «هإووم؟ الحاليةء اذ يجب خروج المستخدم ثم دخوله مرة أخرى الى ال 
)هط لکي تنفذ حدود ال ٥1ا۴‏ ۴. یتم تخصیص ال ۴٣٥۴1٥‏ لل ومول باستخدIم‏ جأ CREATE‏ 
.ALTER USER gy USER‏ 


ملاحظة: يمكن اغلاق وتشغيل ال .(Enable, Disable) Pro fi1e‏ 


‘MANAGING PASSWORD 
بالتحکم بال 0۲۵ wھP باستخدام ال eاگ ہ٥ یمکن:‎ 


ه تحديد عمر محدد لكلمة السر "١١0س‏ وجب على المستخدم تغييرها بعد انتهاء المدة. 

° إجبار المستخدم على اختيار كلمة سر معقدة تتبعرنظام محددة (مثلاً أن لا تتشابه كلمة السر مع اسم 
المستخدم) 

ه اجبار المستخدم عند تغيير كلمة السر عدم اختيار كلمة شر تم استخدامها سابقاً. 

اغلاق ال ٤ں‏ ء۸ الخاص بالمستخدم عند فشل ادخال#كلمة السر لعدد محدد (مثل فشل ادخال كلمة 
السر لثلاث مرات). 


:Locking Account 


یمکن غلق ال )nړAccou‏ بشکل اوتوماتیکي عند فشل الدخول الى Account Û‏ عند كتابة كلمة سر خاطئة 
لعدد من المرات» كما يمكن تحديد المدة التي يظل فيها ال ٤مuهءء۸‏ مغلق عبر تحديد العاملين التاليين: 


:۴۸1LED_L06GING_ATTEMPTS *‏ عدد المرات التي يسمح فيها ادخال كلمة سر خاظئة 
قبل أن يتم غلق ال ٤سهءء۸»‏ مثل آن تحدد القيمة بثلاث محاولات وبعد المحاولة الثالثة يغلق ال 
.Account‏ 

:SSWORD_LOCK_TIME °‏ تحدد قيمته المدة التي یظل فیھا ال u۲‏ ٥ء٥۸‏ مغلق› وبعد 
انتهاء المدة يفتح ال ٤‏ ںهءء۸ بشكل أوتوماتيکي (مثلاً بعد 3 أيام). 


کما یمکن لل 8۸( غلق ال ۸٥٥٥٤‏ أو فتحه باستخدام جملة 11۲٤۸ 0S۴‏ ۸» في حالة غلق ال 
Account‏ بواسطة ال D8۸‏ لا یمکن فتحھ أوتوماتیکیاً بل یجب أن یتم فتحھ عبر ال 8۸( فقطہ 
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:Password Expiration 


يمكن تحديد المدة التي یجب على المستخدمين تغيير كلمة السر 0۲d"‏ wوویو۲'‏ بشكل دوري› کأن یجبر 
المستخدميين تغيير كلمة السر كل شهر. يمكن ايضاً اعطاء مهلة اضافية عند انتهاء المدة التي يجب تغيير 
كلمة السر » بحيث بعد دخول المستخدم الى مءدطها0a›‏ يظهر رسالة تحذيرية تطلب من المستخدم تغيير 
كلمة السر خلال فترة محددة وإلا سوف يتم غلق ال 0u "٤‏ ۸. 


:SSWORD_LIFE_TIME °‏ المدة التي يمكن لكلمة السر أن تظل دون تغييرء في حال عدم 
تغيير كلمة السر خلال المدة يغلق ال ٤‏ uهءء۸‏ وتتحول حالة اÛ .Expired Jll Account‏ 

:SSWORD_GRACE_TIME °‏ بعد ان تنتهي المدة التي يمكن لكلمة السر أن تظل دون 
تغيير» يمكن اعطاء مدة إضافية لتغيير كلمة السر قبل غلق ال )سںهءء۸ مع ظهور رسالة تحذيرية 
لتغيير كلمة السر قبل المدة المحددة. 


مثال: 


عiد‏ تحدıد ao PASSWORD_LIFE_TIME ÛJI‏ ش4ر ۾g PASSWORD_GRACE_ TIME‏ 
بمدة ثلاثة أيام يحدث التالي: بعد انتهاء الشهر دون تغييير كلمة السر وكلما دخل المستخدم الى ال ٤ي Accou‏ 
تظهر رسالة تحذيرية تطالب المستخدم من تغيير كلمة السر خلال 3 أيام وإلا سوف يتم غلق ال .Accou n‏ 


:Password Histor 


يمكن اجبار المستخدم على اختيار كلمة سر لم تستخدم رمن قبل أبداً أو منعه من استخدام كلمة سر قديمة خلال 
فترة محددة. 


:ASSWORD_REUSE_TIME‏ تحدد عدد مز(الأيام قبل أن يتم اعادة استخدام كلمة سر 
قديمة مرة أخرى. 

:SSWORD_REUSE_MAX‏ تحدد عدد الماترالتي يمكن ان يتم استخدام كلمة السر 
القديمة. يمكن اجبار المستخدم بعدم استخدام كلمة سر قديمة أبدا بوضع قيمة العامل صفر. 


ملاحظة: لا يمكن تحديد قيمة للعامليين معا ابداًء اذا تم تحديد قيمة أحد العامليين يجب وضع قيمة الأخر 
.Unlimited‏ 


:Password Verification 


يمكن وضع قوانيين لتسمية كلمة السر باستخدام .۲1/8Q1‏ من القوانيين التي يمكن تحديدها أن لا تكون 
كلمة السر مطابقة لإسم المستخدم أو يجب أن تحتوي كلمة السر على أرقام و أحرف معا وكل ما يساعد على 
تكوين كلمة سر معقدة يصعب التكهن بها. 
:PASSWORD_VERIFY_ FUNCTION °‏ لتحدید اÛ P/Q Function‏ التي سوف 
تستخدم في وضع قوانيين على اختيار كلمة السر. 


ملاحظة: یجب تکوین ال ہەناcرں۴‏ في ال S۷58 Sea‏ › ویجب ان تکون من نوع ۰801٥41‏ أي أن 
الناتج اما صح ''eں "۲٣‏ أو خطاً "eء[ھ۴''.‏ 
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یوفر Oracle Server Û‏ ضمن ال q1ئٍ.g ERIFY_FUNCTION « utp wd‏ ۷ التي یمکن ان 
تستخدم لوضع قوانيين لكلمة السر اذا تم تحديدها في .PASSWORD_VERIFY_ FUNCTION‏ 


:VERIFY_FUNCTION J! jııنlق‎ 


ه أن لا يقل حجم كلمة السر عن اربع خانات» وأن يكون من ضمنها على الأقل حرف واحد ورقم واحد و 
رمز خاص واحد مثل $. 

ه أن لا تتطابق كلمة السر مع اسم المستخدم. 

ه أن تختلف كلمة السر الجديدة عن التي قبلها على الأقل بثلاث خانات» مثلاً لو كانت كلمة السر القديمة 
هي 8$ N1‏ › فلا تقبل كلمة السر الجديدة اذا كانت N1753‏ على اعتبار وجود اختلافيين اثنين فقط 
هما (3,7). 


:CREATING PROFILE TO MANAGE PASSWORD 
سوه باتباع القاعدة التالية:‎ 0١ لإدارة ال‎ ۴۴11٥ یمکن تکوین‎ 


CREATE PROFILE profile name LIMIT 

[FAILED LOGING_ATTEMPTS number] 

[PASSWORD_ LOCK TIME number _ of days] 

[PASSWORD_LIFE TIME number_of day] 

[PASSWORD_ GRACE _ TIME number of dãyš] 
[{(PASSWORD_REUSE_TIME | PASSWORD REUSE_MAX} 
number of days] 

[PASSWORD_VERIFY_ FUNCTION {fnction name | NULL | DEEAULT}] 


في القاعدة, 


:)PASSWORD_REÛE_TIME | PASSWORD_REUSE_MAX}‏ جمع العاملیین 
بين إ ) يدل على السماح بوضع قيمة لأحدهما ولا یمکن”لگليتهما كما تم ذكره مسبقاً. 
٠‏ يمكن وضع القيمة .(number_of_days «number) jz Îضge UNLIMITED‏ 


ملاحظة: كل العوامل اختيارية واذا لم يتم كتابتها يؤخذ القيمة ال )وء( وهي لء)iصiاnا.‏ 


مثال تطبيقي 8.1: 
لتکوین ۴۴1٥‏ للتحكم بكلمة السر : 


CREATE PROFILE myprofile LIMIT 
FAILED _ LOGING_ATTEMPTS 3 
PASSWORD_LOCK TIME 5 
PASSWORD_LIFE_ TIME 15 
PASSWORD_GRACE_TIME 7 
PASSWORD_REUSE_TIME 15 
PASSWORD_VERIFY_FUNCTION verify_function; 
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ملاحظة: لاستخدام الساعات أو الدقائق عوضاً عن الأيام تستخدم القيمة 1/24 للدلالة على يوم واحد ويستخدم 
0 للدلالة على دقيقة واحدة. 


لتحویل ٥۴٥۴1٥‏ باستخدام ال 01یو :٤٥‏ 


ادخل الى ال .Standalone رڊعe Console‏ 

اضغط على اسم Database Û‏ لکي تظهر نافذة تطلب من اسم المستخدم و كلمة السر. 

أدخل اسم المستخدم وكلمة السر مع التاكد من اختيار S584؟S۷$‏ عوضاً عن إوصرإه.. 

.Security Manager J| + اضغخط على‎ 

اضغط بواسطة الزر اليمين للفأرة على مجلد ال ماا؟ه ۴ واختر من القائمة التي تظهر ٥٤4٠إ°.‏ 
في النافذة الجديدةء ادخل اسم ال ٥ان؟ه۲.‏ 

ادخل الى قائمة 0U‏ wوووP‏ وادخل البیانات التي ترید. 

اضغط علی ٥)4٥إC٤.‏ 


ملاحظة: سوف يأتي لاحقاً كيفية تخصیص P۲۴11]‏ للمستخدم "إمءل". 


:ALTERING PROFILE 


يمكن تغيير قيم العوامل باستخدام جم ۸L ER PROPILE‏ › كما في المثال 8.2. 


مثال تطبيقي 8.2: 


ALTER PROFILE mypro file 
FAILEDSLOGING_ATTEMPTS 2 
PASSWORD:LOCK_ TIME UNLIMITED 
PASSWORD_LIFE_TIME 10 
PASSWORD_GRACE_TIME 7/24 
PASSWORD_REUSE_TIME 10 
PASSWORD_VERIFY_FUNCTION verify_function; 


أو باستخدام ال :٤ ٥401e‏ 


ادخل الى ال °٥" 01e‏ عبر .Standalone‏ 

اضغط على اسم ال مءطهه( لكي تظهر نافذة تطلب من اسم المستخدم وكلمة السر. 

أدخل اسم المستخدم وكلمة السر مع التاكد من اختيار 84 S۷50‏ عوضاً عن إوإإه.. 
اضغط على + .Security Manager J|‏ 

اضغط علی + ال ع۴1٥٥‏ واختر اسم ال م1گه۴ المراد تعديله. 

تظهر الخواص في النافذة الیمنی› عدل البیانات القائمة ۴7۷0۲۵ ثم اضغط علیرآم‌م ۸ . 


ملاحظة: التعديلات التي تحدث لل ٣٣1٥‏ بواسطة L1 r ER PROFILE‏ ۸ أو عبر ال C٥s01e‏ لا تؤثر 
على ال «10ووم؟ الحالي للمستخدميين» بل عند دخول المستخدميين في المرة القادمة (ال رمذووم؟ القادم). 
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:DROPPING PROFILE 
عبر استخدام القاعدة التالية:‎ DROP PROFILE باستخدام جملة‎ ۴٣٥۴1٥ یمکن حذف ال‎ 
DROP PROFILE profile name [CASCADE]; 

في القاعدة: 

:CASCDE ۰‏ عند کتابتھا یقوم الأوراکل بحذف ٥"‏ kمںء‌۸8"‏ ال ۴٥۴11٥‏ من المستخدمیین الذين 

.Default Profile J| خصص لهم وتحويلهم اذى‎ 
:8.3 مثال تطبيقي‎ 
:Pr ٥۴] لحذف‎ 
DROP PROFILE myprofile CASCADE; 

أو باستخدام ال 0[eو"ه°٤:‏ 
ادخل الى ال C٥101‏ عبرع .Standal0 n‏ 
اضغط على اسم Database Û‏ لکي تظهر نافذة تطلب من اسم المستخدم و كلمة السسر. 
أدخل اسم المستخدم وكلمة السر مع(إالتاكد من اختيار S۷5584۸4‏ عوضاً عن إوصإه.. 
اضغط على + .Sêcurity Manager J|‏ 
اضغط على + ال ٥1گه‏ ۴ واختر اسم ال اذى المراد حذفه ثم بواسطة الزر اليمين للفارة اختر 
من القائمة “۸٠0۷٥”‏ (يمكن استخدام قائمة†ءع زط0 ثم 8٠٠0۷٠‏ عوضاً عن الزر اليميين 


للفأرة). 
اختر و۷6. 


ملاحظات: 


1- لا يمکن حذف .Default Profile J|‏ 
2- عملية الحذف لا توثر على ال «هاووم؟ الحالية للمستخدميين. 
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RESOURCE MANAGEMENT 


بالتحکم بال و6٥ںمءم8‏ باستخدام ال م1اگه ۴ يمكن تنفيذ عدد من القيود منها تحديد أقصى وقت يمكن 
للمستخدم ان يظل متصلاً بال مءءوطه)ه( › وأقصى وقت يمكن أن يظل المستخدم في ال مووطه)0a‏ دون 
القيام بمهمات "ء[4[" › وتحديد عدد ال ور مإووم؟ التي يمكن للمستخدم أن يحصل عليها في نفس الوقت. 
يجب تحدıد‏ llعlمJ Initiliazation Parameter File gû RESOURCE_LIMIT "Parameter"‏ 
بالقيمة 1۸1٤‏ لكي نتمكن من التحكم بال sعcإuموم‌R‏ » مع الإعتبار أن القيمة ال )إuوfء5‏ هي 
٤ا۴۸‏ يمكن تغيير قيمة العامل بطريقة دايناميكية تظل سارية المفعول الى أن يحدث إغلاق لل 
Database‏ باستخدام ER SYSTEM‏ ۸1۲ کما في المثال 8.4. 


مثال تطبيقي 8.4: 
لتغيير قيمة العامل "٤500 R٣E٤_L1M117‏ بطريقة دايناميكية: 


ALTER SYSTEM SET RESOURCE LIMIT = TRUE; 


للتحكم بال و6ءإں‌هءء8R‏ يتم تحديد العواكل التالية في ال 1ن۴ ۲: 


:)P1_PER_SESSION °‏ يتم تحگيدركم من الوقت يمكن لل «هاووم؟ الإستهلاك من وقت ال 
1 الذي هو المعالج "0۲ء٠٠٠۲"‏ فيجهاز الكمبيوتر الذي يتم فيه كل العمليات (يمكن إطلاق 
عليه اسم "عقل الكمبيوتر ")» بحيث يتم تحديآ قيمة العامل بأجزاء من الثانية. 

:)P1_PER_CALL‏ يتم تحديد كم من الوقت/يمگن لجتملة واحدة من جمل 5Q1‏ الإستهلاك من 
وقت ال €۴€ بحیث یتم تحدید قيمة العامل بأجزاء مڻالتانية. 

:SE5S][0NS_PER_USER‏ تحدد كم و«رمزووم؟ يكن للمستخدم أن يملك في ذات الوقت. 
تذكر من الفصل الأول أنه يمكن للمستخدم الواحد اين يكو أكثر من «هإوومS‏ واحد في نفس الوقت 
اذا استخدم آكثر من برنامج مثل SQ PS‏ و ORACLE FORMS‏ عدا بعض الحالات 
القليلة. 

:)0NNECT_TIME °‏ يحدد المدة بالدقانق التي يمكن للمستخدم أو ال «ه1ووم؟ البقاء متصلاً 
بال موو اواو( بحيث عند انتهاء المدة يتم اخراج المستخدم من ال مءوطه٤ه(‏ وإنهاء عمل ال 
Session‏ و عمل )4 ط11 R‏ للمهمات التي تعمل أو لم یحدث لھا 1 .٤٥۳‏ 

:IDLE_TIME °»‏ يحدد المدة بالدقائق التي یمکن E‏ أو ال ر0وومع؟ البقاء متصلاً بال 
6 بدون القيام بمهمات» بحيث عند انتهاء المدة يتم اخراج اسم من .Database Û|‏ 

٠‏ E_S6۸آPR][۷A:‏ لتحديد المساحة الخاصة المخورة لکل ره‌ذوومS‏ في ال S6۸‏ (خاص فقط 
.(Shared Server‏ 

:L10G1A1_READS_PER_SESSION‏ تحدد عدد ال وی810 وھ التي یمکن قرائتھا 
أو استخراج البيانات منها في ال n‏ هذوومS‏ (يمكن أن تمنع استخراج أحجام بيانات كبيرة). 

:L10G1CA1L_READS_PER_ CALL °‏ تحدد عدد ال ]810 Data‏ استخراج البیانات منھا 
لكل جملة SQ]‏ واحدة. 

gy CPU_PER_SESSION ja JÛ جع‎ Jلصاح‎ gy :COMPOSITE_LIMIT ° 
PRIVATE_SGA» LOGICAL_READS_PER_CALLs CONNECT_TIME 
.Rءي0u‎ ce لمعرفة القيمة الكاملة لل و0‎ 
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:CREATING PROFILE TO MANAGE RESOURCES 
لإدارة ال ومءإuمءم8 باتباع القاعدة التالية:‎ ۴۴1٥ یمکن تکوین‎ 


CREATE PROFILE profile_ name LIMIT 
[SESSIONS_PER_ USER nl] 
[CPU_PER_SESSION n1] 
[CONNECT_TIME n1] 

[IDLE_TIME n1] 

[CPU_PER_ CALL n1] 
[LOGICAL READS _PER_SESSION n1] 
[LOGICAL READS _PER_CALL n1] 
[COMPOSITE_LIMIT n1] 
[PRIVATE_SGA n2] 


في القاعدة: 


1": هي أحدى هذه اقم .UNLIMITED, DEFAULT, NUMBER‏ 
هه 2: هي أحدى هذ الق .UNLIMITED, DEFAULT, NUMBER K|M‏ 


مثال تطبيقي 8.5: 
لتکوین ۴٣٥۴1‏ للتحکم بال Resources‏ : 


CREATE PROFILE myprofile LIMIT 
SESSIONS_PER_USER 3 
CPU_PERSSESSION UNLIMITED 
IDLE TIME 15 
CONNECT_TIME 90; 


لتحویل ۴1 باستخدام ال :٤٥٥ 1501e‏ 


ادخل الى ال Co ns01e‏ عښر .Standalone‏ 

اضغط على اسم Database Û‏ لکي تظهر نافذة تطلب من اسم المستخدم و كلمة السسر. 

أدخل اسم المستخدم وكلمة السر مع التاكد من اختيار 84 $۷95 عوضاً عن إوصإه.. 

.Security Manager J| + اضغخط على‎ 

اضغط بواسطة الزر اليمين للفأرة على مجلد ال ٥اا؟هإ۴‏ واختر من القائمة التي تظهر م٤4٠)°.‏ 
في النافذة الجديدةء ادخل اسم ال مان0۴ ۲. 

ادخل البيانات التي تريد في قائمة إوإءرمء6. 

.٤)۲٥4 ٤٥ اضغط علی‎ 
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:USING DATABASE RESOURCE MANAGER 


یمکن استخدام اÛ Database Resource Manager‏ لتوفیر تحکم أکبر لل م۷امS 0٤1e‏ علی ال 
85 ه8 وكيفية تخصيصها. يجب أن يكون للمستخدم ال معء ]11ر۴1 اللازمة للتحكم بال مووطوat(‏ 
.ADMINISTER_RESOURCE_MANAGER privilege gas Resource Manager‏ 


ıتjع Resource Manager J|‏ atabaseط‏ الى أربعة أجزاء هي: 


:C0NSUMER GROUP °‏ مجموعة من المستخدمیین یتشارکون في ذات قیم ال ces‏ uهیRe‏ 
التي يحتاجونها (كأن يخصص ١11٤ه٣۴‏ واحد لكل مجموعة لأن لديهم ذات الإحتياجات من ال 
.(Resources‏ 

.Consumer Group Û JF Resources J| gıjgتl‎ bط¦þخ‎ :PLAN 

.Consumer Groups Jİ Resources JI gajgî طر‎ :ALLOCATION METHOD 

:PLAN DIRECTIVES‏ یستخدم من قبل ال D8۸‏ لتوزیع ال ۴1.۸۸8 علی ال 
.Consumer Groups‏ 


ملاحظة: معلومات أكثر حول ال Resource Manager‏ atabaseط‏ وكيفية استخدامه في دراسة الإمتحان 
الرابع من امتحانات ال D8۸‏ 9iءOrac[e.‏ 


.Managing Undo Data درس‎ „û Database Resource Manager JÛ Iiãرطت تذکر:‎ 


:QUERYING INFORMATION 
ا۲:‎ 0۴11e للحصول على معلومات حول ال‎ 
یستخدم ال‎ › ۴٣ ٥۴ا[e للحصول علی معلومات حول قیم عوامل ال‎ :(8B۸_PROFILES ° 
سووو۴ أو‎ 0U لتحدید نوع العوامل الھرالاستخراجھا (أما‎ Resource_ Type Column 
.(Kerne] lik ınصتîو‎ Resources 
SELECT * FROM DBA_PROFILES 
WHERE PROFILE = ‘myprofile? 
AND RESOURCE_TYPE = ‘KERNEL’; 

لمعرفة كلمة السر للمستخدم (بشكل مشفر) وحالة ال :۸cc0u)‏ 


DBA USERS‏ : معلومات حول اسم المستخدم وكلمة السر وحالة ال Account)‏ (مغلق۔ یعمل). 


للحصول على معلومات حول Resource Cost ÛJI‏ )من اwتڂڏlIم :(COMPOSITE_LIMIT‏ 


:RESOURCE_COST *‏ معلومات حول الأربع عوامل التي يدد .Composite_Limit‏ 


141 


MANAGING USERS 


لكي يتمكن ال 84( من منح فرصة الدخول الى ال مودطه)هدD‏ للموظفين › يجب منح كل واحد منهم 
Account)‏ یتکون من اسم مستخدم وکلمة سر یعرف هذا ال ٤ں‏ ہ٥۸‏ باسم ۲٥ءآ].‏ یمکن تخصیص لکل 
مستخدم ممیزات و gesم][۴r¡v¡i‏ و ۴¡1eگ Pro‏ › و "ab espace‏ لتکوین العناصر "ء٤c‏ زط0" فیهاء 

و٤2 "em porary "ab esp‏ لتخزين البيانات المؤقته التي تنتج عن عمليات المستخدم» كما يمكن تحديد 
مساحة خاصة للمستخدم من كل ء4 مءع1ط ه۲ تعرف باسم ووا 4٥٥۵ u0‏ 1ط ۲4. كل العناصر 
"زط0" التي يملكها المستخدم في ال عط ٤ھ(‏ (مثل de×esہ[ ۷1ew,‏ ,٥1ط‏ ھ۲) تعرف باسم 
Sch"‏ ولا يمكن للمستخدم الواحد أن يكون له أكثر من 4.٥1ء$‏ واحدة. 


:CREATING USERS 
لتكوين ١ءء جديد تستخدم القاعدة التالية:‎ 


CREATE USER user_ name 

IDENTIFIED [BY password | EXTERNALLY] 

[DEFAULT TABLESPACE Tablespace_name] 

[TEMPORARY TABLESPACE Tablespace, name] 

[QUOTA {number K|M | UNLIMITED} ON Tabléspace_ name, ...] 
[PASSWORD EXPIRE] 

[ACCOUNT {LOCK | UNLOCK}] 

[PROFILE {profile _ name | DEFAULTY] 


في القاعدةء 


:E×X×ERNALLY‏ سوف نتطرق لھا بعد قلیل. 

:DEFAULT TABLESPACE °‏ تحديد ال ءءدمء6[طه٠‏ التي سوف تخزن العناصر التي قد 
يكونها المستخدم مستقبلا. 

TEMPORARY TABLESPACE‏ : تحديد ال remporary abاespa ce‏ التي سوف 
يتم تخزين البيانات المؤقتة الناتجة عن مهام المستخدم. 

٠ه‏ 01۸ا: تحديد مساحة محددة من أي ءء4مءء1ط11 تخصص للمستخدم لتخزين عناصر 
"ects‌ز0b"‏ فیها. 

SWORD EXPIRE °‏ : لإجبار المستخدم على تغيير كلمة السرء التي غرفت بواسطة 58۸ 
عند تكوين ال ٤ں‏ ٥ء۸‏ عند دخول المستخدم الى ال ٤مںuهءء۸‏ مباشرة. 

:C C001 ۰‏ لتحدید اذا ما کان یرید ال 8۸( تکوین ال ٤ہu ۸٥٥‏ جاھز للعمل مباشرة أو أن 
رکون مغن تم رتم فته ب فترة. 

PROFILE‏ : تحدید ال مe[اfم‏ ا۴ المخصص للمستخدم. 
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مثال تطبيقي 8.6: 
لتکوین ۲٥ء‏ جدید : 


CREATE USER Ahmad 
IDENTIFIED BY newemp 
DEFAULT TABLESPACE data 
TEMPORARY TABLESPACE temp 
QUOTA UNLIMITED ON users 
QUOTA 2M ON indx 
QUOTA 10M ON data 
PASSWORD EXPIRE; 


لتکوین ءل باستخدام ال 01یہ :٤٥‏ 


ادخل الى ال Cons01¢‏ عڊر .Standalone‏ 

اضغط على اسم ال مووطه)ه لكي تظهر نافذة تطلب من اسم المستخدم و كلمة السر. 

أدخل اسم المستخدم وكلمة السر مع التاكد من اختيار S۷5584۸4‏ عوضاً عن إوصإه.. 
اضغط على + .Security Manager Û|‏ 

اضغط بواسطة الزر اليمين للفأرة على مجلد ال ءءء واختر من القائمة التي تظهر ٥٤۸٠إ).‏ 
في النافذة الجديدةء ادخل البياناتفيقائمة [4٥"ء6‏ وقائمة .©1U0714‏ 

اضغط علی ٥)4٥إC٤.‏ 


:Operating System Authentication 


يمكن السماح للمستخدميين الدخول الى ال ءءوطه)ه( دون استخدام كلمة سر › هذا يعني بمجرد استطاعة 
المستخدم الدخول الى نظام التشغيل عبر نظام الحماية المعمول فيه في نظام التشغيل (قد يكون كلمة سر خاصة 
بنظام التشغيل patin System"‏ ") يستطيع المستخدم الدخول الى ال #ووطه)ه 0 دون الحاجة الى 
كلمة سر خاصة بالأوراكل. لتطبيق هذا النظام يجب استخدام كلمة E×1٤R۸ N4۸1۷‏ في جملة 

CREATE USER‏ بتحديد العامل U1 HENT1_PREF|IX‏ 08_۸۸ یمکن تمییزاسم المستخدم في نظام 
التشغيل واسم المستخدم في ال مووطو)د › حيث أن القيمة ال ٤ا‏ وء لهذا العامل هي ۲5$ 0. 


متال: 


اذا كان المستخدم مؤهل للدخول عبر حماية نظام التشغيل ( التي تطلب من المستخدم كتابة اسم و كلمة سر) 
الى ال مووطه)ه( وكان اسم المستخدم في نظام حماية نظام التشغيل هو لد ط۸ فإن اسم المستخدم في ال 
.OPSŞ$Ahmad jùyكı Database‏ 

عندما يطلب المستخدم 4 .ط۸ الدخول الى ال مءوطه)ه( ›» فليس مطلوباً من ادخال كلمة سر أو اسم 
مستخدم اذ يقوم الأوراكل بمعرفة اسم المستخدم في نظام التشغيل (ل وإ ط۸) وربطه مع ال Acco "٤‏ 
الخاص به .(OPS$Ah144(‏ 
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ملاحظة: تغيير قيمة ال ×۴1 05S_A U1" ګEN1_ PRE‏ فد يؤدي الى منع المستخدميين من الدخول الى ال 
se‏ t4هط‏ (الذين يسمح لهم الدخول الى مووطوه)ه بدون كلمة سر). 


يمکن استخدام عامل أخر ھو EMOTE_0S_۸ UT HE N1‏ "۴ لتشغيل أوغلق امكانية الإتصال بال 
Remote Database‏ عبر نظام التشغیل (لا ينصح باستخدامه لإمكانية حدوث اختراق لل وط ه٤0‏ ). 
مثال: 

مثال على استخدام R"EMOTE_ O0S_AUTHENT‏ » دخول المستخدم (لديه إمكانية الدخول الى ال 
)هط عبر حماية نظام التشغیل) الى نظام تشغیل (مثل ال ×زہا) متصل مع Orac[e Sever‏ 
الموجود على جهاز أخر» في حالة وضع قيمة العامل ٠۲۲٠‏ فإن المستخدم يستطيع الإتصال بال 


Database‏ أما في حالة القيمة مء[إه۴ (هي ال ٤اuںه؟هء0)‏ فإن المستخدم لا يستطيع الإتصال بال 
ata‏ ويستطيع فقط اذا كان ال إماءS‏ م[ءهإ0 موجود على ذات الجهاز الذي دخل إليه. 


ORACLE SERWER INSTALLED HERE 


CONNECTION 


اا 


NO ORACLE SERVER INSTALLED 
841 رسم‎ 


:ALTERING USERS 

Temporary ÛJI Î Default Tab1espace J| رııغت لكي ڌم‎ ۸1۲٤۸ ل‎ SER يمکن استخدام جملة‎ 
.Quota Û! yİ Tablespace 

مثال تطبيقي 8.7: 

لتغییر ال ٤٥ں‏ للمستخدم: 


ALTER USER Ahmad 
QUOTA 0 ON users; 


ملاحظة: في حالة تغيير قيمة ال ٤0ں‏ الى صفر وكان للمستخدم 141٥‏ في «Users Tab] espace Û|‏ 
فان هذه ال ۲۵1۲ لا یمکن أن یکبر حجمها أبداً (لا تستطیع حجز مزید من ال .)٤×)٤٥ ٤s‏ 
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أو عبر ال 501e‏ «هC€:‏ 


ادخل الى ال C001‏ عبر .Standalone‏ 

اضغط على اسم Database Û‏ لکي تظهر نافذة تطلب من اسم المستخدم وكلمة السر. 
أدخل اسم المستخدم وكلمة السر مع التاكد من اختيار S۷584‏ عوضاً عن إوصرإ٥..‏ 
اضغخط على + .Security Manager J|‏ 

اضغط على + بجانب المجلد ءامو ا› ثم اختر اسم المستخدم. 

غير البيانات في النافذة اليمنى. 

اضغط على رامم۸. 


:DROPPING USERS 
يمكن حذف مستخدم من ال م44 طه)هD باستخدام القاعدة:‎ 

DROP USER user name [CASCADE] 
في القاعدة:‎ 


:AS CADE‏ باضافتها الى الجملة(يتم حذف كل العناصر "ءءء زط0" التي كونها المستخدم في 
ال وء طءS؟‏ الخاصه به. 


ملاحظة: لا یمکن حذف مستخدم متصل بال 46ط 4ھ ¢5 يمکن استعمال × SESS10‏ 1ا1 لإخراج 
المستخدم ثم حذفه من ال #ءوطه)04. 


مثال تطبيقي 8.8: 


لحذف مستخدم: 
DROP USER Ahmad;‏ 


:QUERYING INFORMATION 


:D(BA_ USERS *‏ یمکن الحصول علی معلومات حول اسماء المستخدمیین و ال t٤اںuھ؟5e(‏ 
remporary Tablespace ÛJI Tablespace‏ و اسم ال 1eگPr0‏ وتوقیت تکوین ال ۴0۴11 
وحالة ال ٤ں‏ ٠ء٠۸‏ لجميع المستخدميين وغيرها من المعلومات. 


:D(8BA_1S_QU0AS‏ توفر معلومات حول ال وو٤‏ 0ں المخصصة للمستخدميين من ال 
.Tablespaces‏ 
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اذہل الت اسح 


إدارة البريفليج و أودبوتين 
وول 


Managing PRIVILEGES & 
AUDITING & ROLES 
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PRIVILEGES 


باستخدام ال ومعم[ذ۷آ۴ يمكن وضع حدود لكل مستخدم في ال مودطه)۰04 مثال على ذلك حدود على 
المهام التي يستطيع تنفيذهاء وحدود على البيانات التي يستطيع تعديلها. يمكن إعطاء ومعم |۷¡" 
للمستخدميین بشكل مباشر أو أن يتم عبر ال و16ه8 › كما يمكن إعطاء ومعم][زرآإ" عامة لجميع 
المستخدميين وذلك عبر إعطاء ال ومعم ]ذر۴ الى مجموعة تعرف باسم عiااuں۴‏ وهي مجموعة ينتمي إليها 
جميع المستخدميين في ال #ووطه)ة0. 


یوجد نوعیین من ال اار1" هما: 


.'"0bطزec)ی'" وضع حدود وقیود علی العناصر‎ :0 BJ EC٣ Privileges 
وضع حدود على المهام التي يستطيع المستخدم تنفيذها في ال‎ :YS EM Privileges 
هط بشکل عام.‎ tabe 


:SYSTEM PRIVILEGES 


یوجد عدد کبیر من ال می۴۷11 صع)ول؟ في ال مءوطه)ه يتم تخصيصها للمستخدمين باستخدام جملة 
GBR ANT‏ ویتم إعادتھا (إلغائھا) من االمستختڌمین باستخدام جملة .N۸ ٤۷ O) ٤‏ یمکن توزیع اÛ System‏ 
Prive‏ الى ثلاثة أقسام › قسم متعلى/بالأءءaط‏ هاه( بشكل عام › والقسم الثاني متعلق بال وء طءS؟S‏ 
الخاصة بالمستخدم › أما القسم الثالث فمتعلق "جال وو ٠1ء5‏ الخاصة بالمستخدميين الأخرين. نسق ال 
ااا" في النوع الثالث والرابع متشابه#من#حيث الجملة ولكن يضاف كلمة ۸١۲‏ للنوع الثالثء مثال 
على ذلك CREATE TABLE‏ (النوع الثاني( و CREATE ANY TABÊE‏ (النوع الثالث). 


:System Privileges J| ja 


ALTER SYSTEM 

ALTER SESSION 

ALTER DATABASE 
CREATE TABLESPACE 
CREATE TABLE 

CREATE PROCEDURE 
CREATE CLUSTER 
CREATE SESSION 
RESTRICTED SESSION 
CREATE ANY TABLE 
ALTER ANY TABLE 
DROP ANY TABLE 
SELECT ANY TABLE 
CREATE ANY INDEX 
ALTER ANY INDEX 
DROP ANY INDEX 
CREATE ANY SEQUENCE 
ALTER TABLESPACE 
DROP TABLESPACE 
UNLIMITED TABLESPACE 
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SELECT ANY TABLE 
UPDATE ANY TABLE 
DELETE ANY TABLE 
BACKUP ANY TABLE 
INSERT ANY TABLE 
GRANT ANY PRIVILEGE 
GRANT ANY ROLE 
SYSOPER 

SYSDBA 


ملاحظات. 


Lai « ANALYZE INDEX privilege si CREATE INDEX privilege gı ¥ -1 
CREATE TABLE ءlطعإ بحيث |ذ| ت‎ « CREATE TABLE privilege ga jıılaشم‎ 
ل,].‎ ٥× للمستخدم یستطیع تکوین‎ 


.CREATE TABLE privilege J| jaض¦‎ ùa DROP TABLE Privilege -2 
.CREATE PROCEDURE Privilege J| jaض‎ ùa DROP PROCEDURE privilege -3 
.CREATE CLUSTER privilege JI jaa, ja? DROP CLUSTER privilege -4 


UNLIMITED TABLESPACE privilege -5‏ توفر إمكانية استخدام أي مساحة في أي 
"besp‏ › ولکن تخصص فقط للمستخدمیین ولاپیمکن تخصیصها لل 16اه ۸. 


6- لكي يستطيع المستخدم عمل م)ے ,ںآ لاي ٥1ط‏ ھ۲ قي أي و٥طءS‏ یجب أن یخصص له 5۸0۶۲ 
.ANY TABLE‏ 


:Protecting the Dictionary 


عندما يتم منح الnتخدjııa «SELECT ANY TABLE yi ALTER ANY TABLE‏ ڍصبح 

بإامكان المستخدمیین الدخول أو استخدام ال )زط0 راهہهذاء1 » وهذا قد يشكل خطر على ال 
.Databaْse‏ يوفر الأوراكل الoعامل DIC] 0NARY_ACCESSIB1L[ TY‏ _07 من عوامل 
1nitialiation Parameter File‏ الذي يمكن ال D84‏ في التحكم في «Dictionary Objects JI‏ 
بحيث عند وضع قيمة العامل مء1ه۴ › يتم منع المستخدميين من الدخول الى جميع العناصر ضمن ال S۷8‏ 
Schema‏ الذي ملك ال .Dictio nary‏ 
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:Granting System Privilege 
يمكن إعطاء وم عم ]۴1 للمستخدم باستخدام القاعدة التالية:‎ 
GRANT system_ privilege , system_ privilege, ... 
TO {user_name | role name | PUBLIC} , { user_name | role name | PUBLIC} ,.. 
[WITH ADMIN OPTION] 


في القاعدةء 


.Rهاeو کما ذکرنا سابقاً آنه یمکن منح ال وعع ا۴1 لل‎ :Role_ name 
يستطيع المستخدم الذي تلقی ال ٥ع ][1ہ!ا٣ إعطاءها‎ :W ۲H DMIN OPTION ° 


مثال: 
لفهم :WITH ADMIN OPTION‏ 


يوجد ثلاث مستخدمیین الأول هو ال 8۸( والثاني هو 44 ط۸ والثالٹث ھو ےہ 0. قام ال 8۸( بإعطاء 
Ah n2 d/مدختسملل CREATE ANY TABLE‏ مع استخدام »›W1TH ADMIN OPTION‏ في 
هذه الحالة يمكن للمستخدم | CREATE ANY TABLÉÊ £ HÊ A hı ı2‏ للمستخدم ۲ھ 0. ما في حال 
عدم ذکر جملة ×110 WI] ADMIN 0٢0P‏ ۰ فلا یمکن للمستخدم Privilege J| sibe) Ahad‏ 

للمستخدم د.0 › ويجب على ۲و0 الحضول على ال ءعء11رآإ۴ من (المستخدم الذي لدية إمكانية منح 
.DBA ÛJ! ( Privileges ÛJI‏ 


:9.1 مثال تطبيقي‎ 
GRANT CREATE"ANY TABLE TO Ahmad, Omar; 


GRANT ALTER ANY TABLE, ALTER ANY INDEX 
TO Ali WITH ADMIN OPTION; 


أو عبر ال 0[eی«هC€:‏ 


ادخل الى ال Cons01¢‏ عڊر .Standalone‏ 

اضغط على اسم Database Û‏ لکي تظهر نافذة تطلب من اسم المستخدم وكلمة السر. 
أدخل اسم المستخدم وكلمة السر مع التاكد من اختيار S۷584‏ عوضاً عن إوصرإه.. 
اضغخط على + .Security Manager J|‏ 

اضغط على + بجانب المجلد ءإمءا› ثم اختر اسم المستخدم. 

.System Privileges nilقll اختر‎ 

اختر ال ٥ع‏ ء۴1۷1 من القائمة العليا ثم اضغط على المثلث المتجه الى أسفل. 

ضع علامة صح في قسم دنام 0 «ذص ۸4 اذا كنت تريد ذلك. 

اضغط علی رارم ۸. 
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:Revoking System Privilege 


يمكن سحب أو |lزlء Privileges Û‏ الممنوحة للمستخدم باستخدام القاعدة التالية: 


REVOKE system_ privilege , system_privilege, ... 
FROM {user _ name | role_ name | PUBLIC} , { user name | role name | 
PUBLIC} ,.. 


ملاحظة: في بعض الحلات عند سحب معم ]آ۴ من المستخدم يحدث خلل في باقي عناصر المستخدم. مثال 
على ذلك الخلل الذي قد يحدثه إلغاءِ CREATE "ABLE‏ من المستخدم الذي قام بتکوین ۶٥[طھ۲‏ 
وس۰۷1 في هذہ الحالة یحدث خلل لل ws‏ ع۷1 لأن ال وس۷1 معتمدة على ال و6[ط۾1. 


متال: 
عiد Privilege J REVOKE Jaze‏ وتم استخڏدIم .GRANT ÛJ ge WITH ADMIN OPTION‏ 


WITH ADMIN مIدختwlا‎ ga Ahmad للمستخدم‎ CREATE ANY TABLE ءlطþelڊ‎ D84۸ J| قم‎ 
.Omصaإ للمستخدم‎ CREATE ANY TABLE بإڑطاءٍ‎ ۸h 2 وقام المستخدم ل‎ 0P] N 

« Ahmad Û ةحgiaall‎ CREATE ANY TABLE Jİ D8#JIjJبaړ‎ ja REVOKE عند حدوث مر‎ 

Omar ûİ Î «Omar من عند المستخدم‎ CREATE ANY DABLE Ji REVOKE ةılnعe لا يحدث‎ 
“CREATE ANY TABLE ÛJI dn مازال‎ 


مثال تطبيقي 9.2: 


REVOKE CREATE ANY TABLE FROM Ahmad, Omar; 


أو عبر ال 0[eی«هC٤:‏ 


ادخل الى ال 01eی °٥0"‏ عبر .Standalone‏ 

اضغط على اسم Database Û‏ لکي تظهر نافذة تطلب من اسم المستخدم وكلمة السر. 
أدخل اسم المستخدم وكلمة السر مع التاكد من اختيار S۷584‏ عوضاً عن إوصرإ٥..‏ 
اضغخط على + .Security Manager Û‏ 

اضغط على + بجانب المجلد ءموءلا؛ ثم اختر اسم المستخدم. 

.System Privileges ةnأlقلl اختر‎ 

اختر ال ٥عء‏ ۴۷1 من القائمة السفلى ثم اضغط على المثلث المتجه الى أعلى. 

اضغط على رام‌م۸. 
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:OBJECT PRIVILEGES 


Table, View, Sequence, J| Jذlع توفر ال geء]¡P¡v ٤زط0 إمكانية القيام بمهمات محددة‎ 
.Procedure, Function, Package 


:Object Privilege J| ja 

.Table, View, Sequence J| ja بیانات‎ ) ue تمکن المستخدم من استخراج أو قراءة (ر‎ :SELE٣T 
.٣ھ1e,‎ ۷1W تمکن المستخدم من تعدیل البیانات في ال‎ : 1P٤ 

.٣٣طe,‎ ۷1W تمکن المستخدم من حذف البیانات في ال‎ :P E LEE 

.٣۵(1م,‎ ۷1W تمکن المستخدم من إضافة بیانات الی ال‎ :N SERT 

.Table, Sequence, Procedure J| jيyكت‎ Jيدعت ا : تمكن المستخدم من‎ ER 

.۲ھا1e,‎ ۷1W ہ!] في ال‎ ٥× تمکن المستخدم من تکوین‎ :1ND( ٤× 

. تمکن المستخدم من‌رتکوین ره ع٤٣٥۴ في ال 1۲ھ‎ : REFERENCES 


.Procedure, Function J| Jڎûم‎ °P[/SQL تمکن المستخدم من تشغیل برامچ ال‎ :EX×ECU TE 


:Granting Object Privilege 
يمکن إعطاء وع عم ]1ر۴ للمستخدم باستخدام القاعدة التاليةء‎ 
GRANT object_privilege, objec®privilege, ... | ALL [PRIVILEGES] 
ON [schema.] object_ name 
TO {user_name | role name | PUBLIC} ,.... 
[WITH GRANT OPTION] 
في القاعدةء‎ 
Object Privileges JI J slbe¥ :ALL 
يستطيع المستخدم الذي تلقی ال sععم ]۲1۷1 إعطاءها‎ :W1 ۲1 GRANT OPTION 
لمستخدميين أخريين.‎ 
ملاحظات:‎ 


1 لکي يستطيع مستخدم إعطاء ومع ]ذ۴1 ٤زط0‏ الى مستخدم أخر» يجب أن يكون ال ٤ءءزط0‏ في ال 
Schema‏ الخاصة به و Object Privilege oslطe| pû‏ مع استخدIم .WITH GRANT OPTION‏ 


2- لكل مستخدم وععء‌آ¡۴¡۷ ٤ءء‏ زط0 كاملة على ال ءءء زط0 الموجودة في ال و١ءطء$‏ الخاصة به. 
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مثال تطبيقي 9.3: 


GRANT UPDATE ON hr.employees 
TO Ahmad 
WITH GRANT OPTION 


أو عبر ال 0[eو«هC€:‏ 


ادخل الى ال s01e‏ "°0 عبر .Standalone‏ 

اضغط على اسم ال مءطهه( لكي تظهر نافذة تطلب من اسم المستخدم وكلمة السر. 

أدخل اسم المستخدم وكلمة السر مع التاكد من اختيار S۷5S584‏ عوضاً عن إوصإ٥..‏ 
اضغخط على + .Security Manager J|‏ 

اضغط على + بجانب المجلد ءمءل؛ ثم اختر اسم المستخدم الذي ترید أن تعطیه ال ع٥ا¡‏ مثل 
.PM‏ 

.Object Privileges ةnأlقll اختر‎ 

اختر من القائمة العليا اليسرى اسم المستخدم (مثل 1) الذي يملك ال ٤ءءزط0‏ المراد أعطاء 
Privilege‏ لل .PM‏ ثم اختر نوعیة ال c٤‏ زط0 (مثل ٥1ط )٣٣‏ ثم اسم ال ٤زط0‏ (مثل 
(Employees‏ 

اختر نوعية ال eعم‏ ۴۷11 من_القائمة اليمنى (مثل مول ما). 

اضغط على السهم المتجه الىلأسفل. 

اضغط علی رام‌م۸. 


:Revoking Object Privilege 


يمکن سحب أو |lزsl Privileges Û‏ الممنوحة للمستخدم باستخد(ك القاعدة التالية: 


REVOKE object_privilege, object privilege, ... | ALL [PRIVILEGES] 
ON [schema.] object _ name 

FROM {user _name | role name | PUBLIC} ,.... 

[CASCADE CONSTRAINTS] 


ملاحظة: لكي تتم عملية ال مم8 › يجب أن يقوم بالعملية ذات المستخدم الذي قام بعملية ۲ وإ6. 


في القاعدة: 


:CASCDE CONSTRAINTS‏ لحذف ال کر ”ع٥۲٥۴‏ التي تکونت باستخدام 
.REFERENCES privilege‏ 
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مثال: 


.GRANT JI ga WITH GRANT OPTION pIڌخٿwl‎ pûg Privilege Û REVOKE Jaz ie 


WITH GRANT مlدخت~ا‎ ga Ahmad pدختwnll‎ SELECT TABLE ءlطelڊ‎ Ali قام المستخدم‎ 
.0 na! للمستخدم‎ 3S ELE٣CT TABLE بإعطاءٍ‎ ۸h „2| وقام المستخدم‎ »0P1]0N 

عند حدوث أمر RE۷ 0)۴٤‏ من قبل ال SELECT TABLE Û! A11‏ الممنوحة ل ۸14 › یحدث 
عمل SELECT TABLE Jİ REVOKE‏ من عند المستخدم ھم 0» أي أن 0"۲ یفقد 
SELECT TABLE‏ ايضا. 


مثال تطبيقي 9.4 


REVOKE SELECT ON hr.employees 
FROM Ahmad, Omar; 


أو عبر ال ¢[0ی«ه٤:‏ 


ادخل الى ال 501e‏ "°0 عبر .Staîdalone‏ 

اضغط على اسم ال مءهطه)ه( لكي تظهر نافذة تطلب من اسم المستخدم وكلمة السر. 

أدخل اسم المستخدم وكلمة السر مع التاك"من اختيار S۷584‏ عوضاً عن إوصرإه.. 

.Security Manager J| + اضغط على‎ 

اضغط على + بجانب المجلد ءءء ثم اختر اسم الگستخدام الذي ترید استرجاع ال ومعم]¡İ۷ا۴"‏ 
منه. 

.Object Privileges ةnilقll اتر‎ 

اختر ال ٥ع‏ ء۴۷1 من القائمة السفلى ثم اضغط على المثلث المتجه الى أعلى. 

اضغط علی رام‌م۸. 


:QUERYING INFORMATION 


للحصول على معلومات حول :System Privileges JI‏ 


:DBA_SYS_PRIVS‏ توفر معلومات حول ال esعماز۷¡اP System‏ الممنوحة ای ,ومول 
.Roles‏ 


:D(B A_1 AB_ PRIS‏ توفر معلومات حول ال وءعماذ۷آإ۴ ٤ءء‏ زط0 الممنوحة والمستخدم 
الذي منح ال وععم[ذہ۴1 وغيرها. 


:SESS1]0N_PRIVS‏ توفر معلومات حول ال وععء‌آز۷آا۴ ۳ءtءر؟‏ الممنوحة للمستخدم 
الحالى (ىمذوsمS).‏ 
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AUDITING THE DATABASE 


عملية ال عمنازق ں۸ هي عملية مراقبة مهمات ال مووطههD‏ المختلفة بحيث يتم مراقبة أي عمليات مشتبه 
في أنها غير مسموح فيها كأن يقوم مستخدم غير مسموح له بالدخول الى ال مءوطه)ه( بالدخول وحذف 
بيانات من ال مو طها4(. يتم جمع بيانات ومعلومات حول المراقبة في ۸00$ التابعة ل وءطءء $SS‏ » 
أو يمكن جمع هذه المعلومات في ملف خارجي في نظام التشغيل ".ءاءر؟ ع«نخهإءم0". لتسجيل 
المعلومات الناتجة عن عملية ال مزق ں۸ › يجب وضع قيمة العامل ۸11 7R‏ 9۲ا۸ بالقيمة True‏ 
أو D8‏ » أو يمكن استخدام ملف خارجي بوضع قيمة العامل 0S‏ أما القيمة ال ٤ا‏ وء للعامل هي 
.N.ONE‏ يقوم الأوراكل بعمل عدذ)1ك ں۸ في بعض الحالات وإن كانت قيمة العامل ٠٠‏ مثل عند تشغيل 
و إغلاق ال مء۸ وو[ أو لمراقبة ال ومعم اذإ الخاصة لل 84( (أو كل مستخدم يملك ومgم]¡v¡اP‏ 
مشابه لل 08۸). 

لل D8۸‏ حرية تحدید اذا ما كان يريد ان تحدث عملية ال ع«ازقں۸ عند المهمة المراد مراقبتها ( ر8 
ssءعءA)‏ أو لكل ال «مذوومS‏ بغض النظر عن عدد المهمات التي تحدث(,10وءه؟S .)8y‏ 


باستخدام عملية ال )زQ‏ ں۸ يمكن مراقبة: 
جمل ال SQ‏ 


.Privileges J| e 
."0(ز٥ء)ء'" العناصر‎ ه٠‎ 


ملاحظة: یطلق علی ۸00$ اسم 11و۲۲ )ل1 وهي من نوع ال و»اطه1 م8 وهي الوحيدة التي يمكن 
لل 8۸( تعدیلھا کما جاء ذکرها سابقاً. 
اذا امتلئٰ ملف ال 1ذإ٣‏ ٤1ل‏ ں۸ بحيث لا يمكن إضافة معلوكاتالمرةاقبة الى الملف › تتأثر جميع جمل ال 
1 المراقبة وعوضا أن تظهر النتائج الطلوبة › تظهر أخطاء 0و٥‏ عهءوم1 ."E ۲۲٠۲‏ ولذلك يجب تفرغة 
ملف ال ]ز۲۲۵ ں۸ بشکل مستمر. للتحکم في حجم ال 1ذ 6۲۲۵زا ں۸ › ینصح باستخدم ال عہ1) Audi‏ 
عند الضرورة فقط › واختيار نوع المراقبة بدقة (ال $1 أو العناضر أو ال وعء1زآ٣۴)‏ » وعدم إعطاء ال 
D1۲ ANY privileges‏ ۸ لمستخدمیین کثیرین واستخدام ر0ذوو6؟ ر8 عوضاً عن وم۸۲ .8y‏ 
ملاحظة: لحذف محتويات ال ھ٣٣‏ ٤ں A‏ « تستخدم جمJ .TRUNCATE JI Î DELETE J|‏ 
يمكن حماية ملف ال 1ذهإ٣‏ ٤ل‏ ں۸ بكتابة التالي: 

AUDIT DELETE ON SYS.AUDS BY ACCESS; 
أخرىء مع مراعاة اعادة‎ ٣a ط1espace الى‎ SYSTEM TABLESPACE Û يفضل نفل ال 5ا۸ من‎ 


تعریف ال وe×ع‏ لہ[ علی کل من ال وروص uں1هC‏ التlئية .(sessionid , ses$tid)‏ 


تذکر: یجب اعادة تعریف ال ومe×م۵.]‏ عند نقل ال و16 .٣۵(‏ 
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مثال تطبيقي 9.5: 
مثال على القيام بعملية عرزا زه ں۸ لجمل ال 8@1: 
لمراقبة جمل ال DD.‏ التي تنفذ على ال و6[طه : 
AUDIT TABLE;‏ 
مثال على القیام بعملية :Privileges JÛ Auditing‏ 
AUDIT CREATE ANY SEQUENCE;‏ 
مثال على القيام بعملية عمن† ں۸ لل :0bjects‏ 


AUDIT UPDATE, DELETE ON HR.EMPLOYEES; 


:AUDITING OPTIONS 
يمكن استخدامها لتحديد عملية المراقبة بشكلأكبر.‎ 
يتم جمع معلومات حول‎ › 5Q1 فلي حالة مراقبة جمل ال‎ ¥ HENEVER SUCCESSFUL ° 
الجمل التي تمت بنجاح ولا يتم تسجيل معلومات حول الجمل التي لم تنجح في القيام بمهمتها.‎ 
یتم جمع‎ › 8Q في حالة مراقبة جمل ال‎ :WW HENEVER NOT SUCCESSFUL ° 
معلومات حول الجمل التي لم تنجح ولا يتم تسجيل إمعلوماثبحول الجمل التي نجحت في القيام‎ 
بمهمتها‎ 


.BY ACCESS ° 
.BY SESSION ° 


مثال تطبيقي 9.6: 
لمراقبة عمليات تكوين ور هذووم؟ (دخول المستخدميين لل مsوطها04)‏ : 
AUDIT SESSION;‏ 
العمليات الناجحة فقط: 
AUDIT SESSION WHENEVER SUCCESSFUL;‏ 
العمليات التي لم تنجح: 


AUDIT SESSION WHENEVER NOT SUCCESSFUL; 
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:NOAUDITING 

لايقاف عملية ال عمنازں A‏ » تستخدم جملة 011 N0۸10‏ مع اضافة الجزء الذي تم مراقبته في عملية 
.Auditing‏ 

مثال تطبيقي 97 

للقيام بعملية :Noauditing‏ 


NOAUDIT UPDATE, DELETE ON HR.EMPLOYEES; 


:QUERYING INFORMATION 

للحصول على معلومات حول ال ڇہ!)Audi:‏ 
L4 DEF _ AUDIT_ OPTS °‏ توفر معلومات حول .Deafult Audit Options J|‏ 
:D(8۸_S1MT_AUDIT_OPTS °‏ توفر معلومات حول عمليات المراقبة على جمل ال اQ؟.‏ 


:D(BA_ PRIY_AUDIT_OPTS *‏ توفرھتغلومات حول عملیات المراقبة علی وeعم]¡۲]v.‏ 


:D(BA_ OBJ_AUDIT_ OPTS °‏ توفر معلوماتر حول عملیات المراقبة على واءe‌زط0.‏ 


للحصول على المعلومات الناتجة من عملية ال عمز)ز۸ud:‏ 
:D8BA_AU DIT TRAIL‏ جميع المعلومات الناتجة من عملية ال عمذ) .A ud‏ 
:D(BA_AUDIT_ OBJECT °‏ المعلومات الناتجة من عملية ال Auditing‏ علذى .Privileges‏ 


DB A_ A UDIT_STATMENT *‏ : المعلومات الناتجة من عملية ال عہن)زقں ۸ على جمل ال 
.SQL‏ 


:D8۸_A U DI_SESSION‏ المعلومات الناتجة من عملية ال ع١)زdں۸‏ على دخول و خروج 
المستخدميين من ال مووطو)0a.‏ 
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MANAGING ROLES 


تسهل ال و8016 عملية إدارة ال ومعع‌][ذہ۴1 لأن ال مإهR‏ عبارة عن مجموعة من ال وeع‏ ]ہ٥‏ تعطى 
أو تلغى من المستخدمين دفعة واحدة. مثال على ذلك اذا راد ال 58۸ إعطاء عشرة ومعم[ہ٣‏ لكل 
مستخدم جديد في ال مءوط هه »۰ فيجب على ال 84( كتابة جملة ۸۸1 عشر مرات › وكذلك الحال 
مع جملة "E VOK٤‏ › اما عند استخدام ال R1٥‏ ۰ یتم کتابة جملة G۸ ANT‏ أو REVOKE‏ مرة واحدة 
فقط. یمکن أن یتکون ال 1۲ه۸ من ال gesم[P¡vi System‏ وال Object Privileges‏ معا › ولا ینتمی ال 
ماRo‏ الى أي 4" عطءS‏ › ویتم تخزین بیانات حول تکوینه في ال راھ" ٥iاء¡D(‏ 04)4. 


:CREATING ROLES 
يمكن تكوين و801 باستخدام القاعدة التالية:‎ 


CREATE ROLE role_ name [NOT IDENTIFIED 
| IDENTIFIED { BY password | EXTERNALLY } 


في القاعدةء 


.R 01e يۇجداڭماية على ال‎ ¥ : NOT DENTIFIED 
مثل استخدام كلمة السر أو غيرها.‎ 8٠16 يوجد حماية علئ,ال‎ :[( ENT 1F]ED 
مثل حماية نظام التشغيل.‎ 8٠1٠ يستخدم حمايتة كاراجية لل‎ :EX×"ERNALLY ° 


ملاحظة: يوجد أنواع حماية أخرى لل م۸01 عدا كلمة الس أىرااه1إء)×5 لا مجال للتطرق لها في الكتاب. 


مثال تطبيقي 9.8: 
لتکوین R01٥‏ : 


CREATE ROLE newusers; 
او:‎ 
CREATE ROLE newusers2 IDENTIFIED BY n6iut300; 


أو عبر ال 0[eی«هC٤:‏ 


ادخل الى ال Console‏ عڊر .Standalone‏ 

اضغط على اسم ال مووطه)ه لكي تظهر نافذة تطلب من اسم المستخدم وكلمة السر. 
أدخل اسم المستخدم وكلمة السر مع التاكد من اختيار S۷9558۸4‏ عوضاً عن إومإه.. 
اضغط على + .Security Manager J|‏ 

اضغط على بالزر اليمين للفأرة على المجلد وم1إمR‏ › ثم اختر من القائمة مtو٠إC.‏ 

ادخل اسم ونظام حماية ال م801 ثم اضغط على ٥٤و٠ءإ)٤.‏ 
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ملاحظات: 


1- بعد تكوين ال R1‏ مباشرة › تكون ال 8٥16‏ خالية تماماً من أي ع11 إ۴ ويمكن استخدام جملة 
GRANT‏ لإعطاء ال Re‏ مجموعة من ال یe‌عم]ز۲|v.‏ 


.CREATE ROLE privilege pدخan‎ sı يجب أن‎ « R01 لتكوين‎ -2 


:PREDEFINED ROLES 
عند تكوين ال مووطه)هD » يتم تكوين مجموعة من ال و16٠8 بشكل أتوماتيكي منها:‎ 
[4)4 تتضمن امكانية الإتصال بال موو‎ 801٥ ضمن هذا ال‎ Pr viاeges‎ Ûا‎ :C0NNECT 
Tables, Views, Synonym, Cluster, ja Jک وتکوین "هiوومS › امكانيه تکوين‎ 


.Database Link 


RESOURCE‏ : ال egesاvi Pri‏ ضمن هذا ال 81۲ تتضمن امکانية تکوین کل من اھ 
.Cluster, Sequence, Functions, Procedures, Triggers‏ 


:SELEEE CATALOG_ROLE °‏ ال Privileges‏ ضمن هذا ال 8016 تتضمن امكانية 
استخراج بیانات ال ر اھ٣‏ ہ٥ا)‏ )9 Data‏ (عمل Query‏ علی ال 16sطھ٣‏ وال .)۷ieWws‏ 


:DELETE_CATALOG_ ROLE °‏ إل egeاPvi‏ ضمن هذا ال م81 تتضمن امكانية حذف 
بياناٽ )اتخدIم .Data Dictionary Ûl ùa (DELETE‏ 


:EXECUTE_CATALOG_ROLE *‏ ال 36 "v6‏ ضمن هذا ال 8٥18‏ تتضمن امكانية 
استخدIم‏ جأ EXECUTE‏ ي .Data Dfttionary ÛJI‏ 


:EXP_ FULL DATABASE‏ ال Privilege‏ ضفل هذا ال 8٥16‏ تتضمن امكانية عمل عملية 
.Database Jİ Export‏ 


:EXP_ FULL _ DATABASE‏ ال egeاPvi‏ ضمن هذا ال 8٥16‏ تتضمن امكانية عمل عملية 
.Database Jİ Import‏ 


ملاحظة: سوف يتم التطرق على عملیات ال 0۲ م×۴E‏ و ال ٤امم_]‏ في دراسة الإمتحان الثالث من امتحانات 
.Oracle9i Û‏ 


تذكر: من أنواع ال sسwعذ۷‏ رإه«هناء¡( 0٤a‏ نوع D8۸_‏ الذي يمكن أن للمستخدم الدخول الى بياناته 
اذا کان يمأ .SELECT_CATALOG_ROLE ÛJI‏ 
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:MODIFYING ROLES 


يمكن تغيير نظام حماية ال م1٠8‏ أو حذف نظام الحماية باستخدام جملة ۸L۲ ER ROLE‏ کما في 
المثال 9.9. 


ملاحظة: لتعديل نظام حماية ال R01‏ › يجب أن يكو أnستخدpم .ALTER ANY ROLE privilege‏ 


لتعديل نظام حماية ال م[هR:‏ 

ALTER ROLE newusers2 IDENTIFIED EXTERNALLY; 
أو احذف نظام الحماية:‎ 

ALTER ROLE newusers NOTIDENTIFIED; 

أو عبر ال 0[eئره٤:‏ 
ادخل الى ال 01eیہ C0‏ عیبر .Stafdaloٍîe‏ 
اضغط على اسم Database Û‏ لکن تظهر نافذة تطلب من اسم المستخدم وكلمة السر. 
أدخل اسم المستخدم وكلمة السر مع التاكدرملن اختيار S(584؟S۷‏ عوضاً عن إوصإه.. 
اضغط على + .Security Manager Û|‏ 
اضغط على + بجانب المجلد وم1هR‏ › ثم اختر اسم ال R٠1٥‏ المراد تعديله. 


في النافذة اليمنى › اختر نظام الحماية من قائمة 6نا .Auth e”14‏ 
اضغط على رام م ۸. 


:ASSIGNING PRIVILEGES TO ROLES 
خالية تماماً من أي ومعم ]۴۷1 ويمكن استخدام جملة‎ 801٥ مباشرة › تكون ال‎ 801٥ بعد تكوين ال‎ 
10 الى المستخدمیین مع ذکر اسم ال 801 بجانب كلمة‎ P1] التي استخدمت لإعطاء وع عم‎ GBR A N1 
.9.10 عوضاً عن اسم المستخدم أو ال عاط ں۴ كما في المثال‎ 
:9.10 مثال تطبيقي‎ 
:Roles ÛJI Jll Privileges slطey‎ 
GRANT CREATE ROLE TO adminusers; 


GRANT SELECT ON HR.EMPLOYEES TO newusers2; 
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أو عبر ال 0[eی«هC€:‏ 


ادخل الى ال Con s01e‏ عبر .Standalone‏ 

اضغط على اسم ال مءهطه)ه( لكي تظهر نافذة تطلب من اسم المستخدم وكلمة السر. 

أدخل اسم المستخدم وكلمة السر مع التاكد من اختيار S۷584‏ عوضاً عن إورإ٥..‏ 

.Security Manager J| + اضغخط على‎ 

اضغط على + بجانب المجلد وم[مR‏ » ثم اختر اسم ال 801 المراد إضافة ومعم‌]۴]۷1 له. 

أختر إما قائمة وsمgم]v¡1¡اP System‏ أو قائمة sەgعاPivİ‏ زط0 » ثم اتبع ذات الخطوات التي 
تم فيها أعطاء المستخدمیین ال ومع م]¡۴|۷. 

۰ اضغط على رام‌م۸. 


:ASSIGNING ROLES TO USERS 
التي استخدمت لإعطاء ومعم ]۲ الى‎ K۸ ۸1 يمكن إعطاء المستخدميين ال و16٥8 بواسطة جملة‎ 
عوضاً عن اسم ال ٥ع [ذں إ۴ كما في المثال‎ 6۸۸A N1 بجانب کلمة‎ R016 المستخدمیین مع ذکر اسم ال‎ 
.9.11 
:9.11 مثال تطبيقي‎ 
:Roles ÛJI Jll Privileges slطey!‎ 
GRANT adminusers T@O"Omar WITH ADMIN OPTION; 
GRANT 'newusers TO Khaled; 
ببعضها.‎ 8٥1٥ کما یمکن دمج‎ 


GRANT newusers TO newusers2; 


ملاحظات: 


1- المستخدم الذي يقوم بتكوين ال 1ه 8R‏ لديه الحق في WH ADMIN OP T1ON‏ على ذلك ال 
.Role‏ 


2- المستخدم الذي يملڭ GRANT ANY ROLE pri vi1ege‏ یستطیع إعطاء أو إلغاء ال وا۸0 من 
المستخدميين. 


3- يمكن تحديد عدد ال وم1هR‏ التي يمكن أن تكون في الحالة ٠1ع‏ باستخدام عامل من عوامل ال 


Intialazation Parameter File‏ هر„ ٧۸× ENABLED _ ROLES‏ الذي قیمته ال )[اهfء5‏ هي 
20. 
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:ASSIGNING DEFAULT ROLES 
ولكن ليس بالضرورة أن تكون كلها في حالة إ(هم۴›‎ › ۸٠1٠ يمكن للمستخدم الواحد أن يملك أكثر من‎ 
٤ ہھb[۲ والذي يتم وضعه في حالۂ‎ 0 مfهںا‎ R01 ولکن یمکن جمع مجموعة من ال و816 لتمثل ال‎ 
تستخدم القاعدة:‎ › 0ءوfں[٤‎ R01٥ بشكل أوتوماتيكي عند دخول المستخدم الى ال مووطه)ه0. لتعيين ال‎ 
ALTER USER user _ name DEFAULT ROLE 
{ role_name , role_name | ALL [EXCEPT role _ name , [role name] ] | NONE } 
في القاعدة:‎ 
.£E×X€) ٤P1 1ا : یمکن تعیین کل ال و16٥8 عدا المشمولییین في جملة‎ ]EX٣CEPT...] 


ملاحظة: يمكن استخدام هذه القاعدة فقط مع ال وم81 الممنوحة مباشرة للمستخدم عبر استخدام ۸1 GR۸‏ 
ولا تنطبق على ال وم801 المدمجة ضمن وءاهR.‏ 


:9.12 مثال تطبيقي‎ 
للمستخدم:‎ (fa )1ں‎ R01٥ لتعیین‎ 
ALTER USER Ahmad DEFAULT ROLE newusers, newusers2; 
ALTER USER Khalid,DEFAULT ROLE ALL; 
ALTER USER Omar DEFAULT ROLE ALL EXCEPT adminusers; 


ALTER USER Ali DEFAULT ROLE NONE; 


أو عبر ال ما0ئره٤:‏ 


ادخل الى ال Console‏ عڊڙر „Standalone‏ 

اضغط على اسم Database Û‏ لکي تظهر نافذة تطلب من اسم المستخدم وكلمة السر. 

أدخل اسم المستخدم وكلمة السر مع التاكد من اختيار S۷584‏ عوضاً عن إوصإ٥..‏ 

.Security Manager J| + اضغخط على‎ 

اضغط على + بجانب المجلد ءعءل › ثم اختر اسم ال مول المراد تعديله. 

في النافذة اليمنى › اختر قائمة 016 ۸› ثم ضع علامة صح اسفل ال ادع( لل م1٠8‏ الذي تريده 
أن یکون {[uںه50ef.‏ 

.۸ اضغط على راصم‎ ٠ 
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:ENABLING AND DISABLING ROLES 
لا يستطيع المستخدم‎ .SE۲ R0٥٤ بین 21ہ و ٥اطھءDi( باستخدام جملة‎ R1 یمکن تحویل حالة ال‎ 
عندما تكون في حالة م[ط ء01 › ويجب تحويل حالتها الى ٥1ط ھم لأستخدام ال‎ 801١ استخدام ال‎ 
فقط على ال رمذوومS ولا تكون التغييرات دائمة › إنما تعود ال‎ 3٤۲ ۴OLګE داخلها. تؤثر ال‎ Privileges 
كلمة سر لتحويل‎ R1١ لوضعها الطبيعي بعد خروج المستخدم من ال مودطو٤د5. عندما يتطلب ال‎ ۴6 
وإن کان‎ D٥ ؟ںو[٤‎ R01٥ ولا ینطبق الحال علی ال‎ › SE R01٤ حالته » يحب كتابة كلمة السر في جملة‎ 
من ضمنه 8164 تتطلب کلة سر لأن ال 1۲هR ٤1ں؟ وء يتم تحويلها الى حالة ٠1ط" بشكل أوتوماتيكي.‎ 
يمكن تحويل حالة ال م801 باستخدام القاعدة التالية:‎ 
SET ROLE 
1 role_name [IDENTIFIED BY PASSWORD] [, role name ....] 


| ALL [EXCEPT [role name, role _ name,...] 
[NONE } 


:9.13 مثال تطبيقي‎ 
:Enab1e الى‎ 801e لتحويل حالة ال‎ 
SET ROLE newusers, depaftA_users; 
SET ROLE newusers2 IDENRIFIED BY n6iut300; ّ 
:adminusersJl#ûÙغ‎ Enable الى‎ R01¢s لتحويل حالة جميع ال‎ 

SET ROLE ALL EXCEPT adminusers; 
لتحويل حالة جميع ال و8016 الى ماطهء0:‎ 


SET ROLE NONE; 


:REMOVING ROLES FROM USERS 
يمكن إلغاء ال وم6[امR من ال ومول باستخدام القاعدة التالية:‎ 


REVOKE role name , role name, ... 
FROM { role_name | PUBLIC} , {role name | PUBLIC} ,..; 


:الءe۶ لإلغاء ال e[مR من ال‎ 
REVOKE newusers FROM Khaled; 


أو عبر ال مامء”ه٤:‏ ذات الطريقة المستخدمة في إلغاء ومعم ]۴:۷1 من ال ومءا. 
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:DROPPING ROLES 


يمكن حذف ال وم1هR‏ من ال مودطهه 0 وبالتالي من ال ومول باستخدام القاعدة التالية: 


DROP ROLE role name ; 


ملاحظة: يحتاج المستخدم الى PROP ANY ROLE privilege‏ لحذف أي R01‏ في ال seھطھ†D4.‏ 


مثال تطبيقي 9.15: 


لحذف ال R01‏ من ال ¢4sطData:‏ 


DROP ROLE newusers2; 


أو باستخدام ال 0[eی,ه°٤:‏ 


ادخل الى ال s01¢ئCon‏ عڊڙر .Standalone‏ 

اضغط على اسم Database Û‏ لکي تظهر نافذة تطلب من اسم المستخدم وكلمة السر. 

أدخل اسم المستخدم وكلمة السر مع التاكد من اختيار S584؟S۷¥‏ عوضاً عن إومإه.. 

.Security Manager J| + اضغط على‎ 

اضغط على + ال ء٥1٠8‏ واخترهاسم(ال 8٠1٥‏ المراد حذفه ثم بواسطة الزر اليمين للفأرة أختر من 
القائمة “R٠0۷”‏ (يمكن استخداام قائمة ٤ءء‏ زط0 ثم ۸8٤٠” 0٠۷٠‏ عوضاً عن الزر اليميين 
للفأرة). 

اختر و۷6. 


:QUERYING INFORMATION 


للحصول على معلومات حول ال وماهR:‏ 


.04ا4طووe توفر معلومات حول جمیع ال 8014 الموجودة في ال‎ :D(8BA_ ROS 


PRS‏ _LEا8۸_R۴O(:‏ توفر معلومات حول ال و16٥8‏ الممنوحة للمستخدمين أو المدمجة مع 
اآاخری. 


:۴"0LE_ ROLE_PRIVS‏ توفر معلومات حول ال وم801 المدمجة مع وم801 أخرى. 


:D8BA_SYS_PR۷8‏ توفر معلومات حول ال ومعم‌۷1آإ۴ ءاور الممنوحة للمستخدمين أو 
لل .R0[s‏ 


.Rم[6و الممنوحة لل‎ System ۲¡v¡]معەs توفر معلومات حول ال‎ :ROLE_SYS_PRIVS 
.Rه[مو توفر معلومات حول ال sەgم]¡v¡ا۴ زط0 الممنوحة لل‎ :ROLE_ A B_PRIVS 


:SESS1[0N_ROLES‏ توفر معلومات حول ال E1414 ® 016s‏ للمستخدم الحالي. 
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اذمل العاشر 


الدعم العالمي 


GLOBALIZATION SUPPORT 


GLOBALIZATION SUPPORT 


المقصود بال ٤ا0‏ ممu؟‏ «هنا)ونادطما › إمكانية استخدام لغات عالمية وتقويمات عالمية في الأوراكل. 


من المميزات التي يوفرھا :Globalization Support J‏ 


إمكانية حفظ واستخراج البيانات باللغة المحلية. 

إمكانية تشغيل ال وع1)اذ) ا مء4طه)ه باللغة المحلية. 

إمكانية عرض ال sمعھووم]۷ ٣٣٠۲‏ باللغة المحلية. 

أمكانية استخدام بعض التقويمات المحلية مثل التقويم الياباني. 

إمكانية عرض الأرقام باللغة المحلية. 

إمكانية استخدام رموز العملات العالمية. 

إمكانية استخدام فارق التقويم الزمني بين الدول. 

إمكانية استخدام مجموعة من النظم لتعريف lأغlٽت"es .Unicode Jia "Encoding Sch e‏ 
التحويل الأوتوماتيكي بين اللغات» أي استخدام المستخدم ٤"ء11ا٣‏ لغة مختلفة عن لغة السيرفر. 


:ENCODING SCHEMES 


يوفر الأوراكل مجموعة من النظم لتعريف اللتغات منها: 


BYTE-EاS][NG:‏ یتم استخدام بایت واحد,لتخزین حرف واحد. یوجد نوعان هما )زا-7 (مثال 
.{WESDEC Jl) 8-bit s (US7ASCII‏ 


AR Y1NG-WD 1۸‏ ۷: يمكن تخزين الحرف الواخ<في أكثر من بايت وتستخدم هذه الطريقة 
غالباً في اللغات الأسيوية مثل الصينية واليابانية (مثال 3٤€‏ و 1۴8 7ا۸132). 


.)۸ 1161۲۴16 یتم تحدید عدد محدد من البایتات' لکل حرف (مثال‎ :۴1XED-WD TH 
نظام معتمد في جميع أنحاء العالم لقدرته على تعريف جميع اللغات والرموز الخاصة‎ : UN] 0٤ 


والرموز المستخدمة في النشر (مثل © ®). يمكن أن تتكون ال ٠0ء‏ 1م من مجموعة من النظم 
المختلفة .(UTF-16 Jlûa) Fixed-Widths (UTF-8 Jlûa) Varying-Width Jû‏ 


:CHOOSING CHARACTER SET 


خلال دراستنا لقاعدة CREATE DATABASE‏ › تعرفنا الى جم CHARACTER SET‏ التي تحدد 
نوعية النظام الخاص باللغة" )ع إماءوإوط٤"‏ الذي سوف يستخدم في ال مووطه)ه0 (مثل 
.)۸A8‏ یستخدم نظام ال Character set‏ لتخزین اسمlء Data gy Columns Jly Tables J|‏ 
في „a Character Set JJ Default J| ãميقll .CHAR, VARCHAR2, LONG, CLOB iı‏ 
استخدام 8011 187۸[. لا یمکن تغییر ال C14۲4) Se)‏ بعد تکوین ال 6ء4طھtھ(‏ عدا في بعض 
الأستثنائات القليلة (مثلاً عندما يكون ال S6٤‏ إماء دإ هط الجديد مطابق بشكل كبير للنوع القديم). 

عملية انتقاء ال ٤ء‏ )اط المناسب تعتمد على الأحتياجات الحالية والمستقبلية معاًء أي في حالة 
وجود احتمال استخدام لغات عديدة في المستقبل» يفضل استخدام Character Set‏ قادر على استیعاب لغات 


عدة. 
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أيضاً يجب الأخذ بالإعتبار نوعية ال S٤‏ إم)ءوإهط المتوفرة في نظام التشغيل " ڇہ1)و١ء0p‏ 
"System‏ اذ أن الإختلاف بين النظاميين يؤدي الى عملية تحويل يقوم بهل الأوراكل مما قي يؤدي الى حدوث 
عبئ وضغط من جراء عملية التحويل › مما قد يؤدي الى ضياع بيانات. 

يعتبر استخدام ٠)ر8-ء1ع‏ ,$1 أفضل من الناحية الفنية والأداء عن استخدام 1)1 W-ع"1ر‏ اه۷ ولكن 
إمكانيات ال م٤‏ ر8-ء[عمذ؟ في تعدد اللغات محدودة جدا. 


.Character Set JÛ مlظۈis‎ Fixed-Width pدختسا ملاحظة: لا يمكن‎ 


:CHOOSING NATIONAL CHARACTER SET 


NATIONAL CHARACTER SET ya CREATE DATABASE ةدعlق يوجد نوع إضافي في‎ 
Default J| ةnıقll‎ .NCHAR, NVARCHAR2, NCLO8B الذي يستخدم لتخزين البيانات في هين‎ 
National Character JÛ يمکن استخدام قیمتان‎ .A۴16 U F16 هي‎ Nationa Character Set Jİ 
بعد‎ National Character Set J| غير‎ jay J .UTF-8§ sg UTF-16 Unicode J فقط هما قيمتا‎ 
تكوين ال مووطه)د( عدا في بعض الأستثنائات القليلة.‎ 

عملية انتقاء ال Nationa1 Character S6٤‏ تعتمد على اللغة المراد استخدامها › ففي حالة اللغات 
الأوروبية يتم حجز بين ٠٤ر8‏ 1 الى م)ر8 2 لكل حرف (أي أن الأحرف لا تحجز مساحة ثابتة بل متغيرة) › 
ولذلك یفضل استخدام 11۴-8 لأنھا من نوع متغیر 2-W 1٤1‏ ,را۷ (من 1 بایت الى بایت 3)ء ولکن 
تعتبر ال 01۴-16 أسرع وأقل عبئ فيال #ووط وغه لأنها من النوع الثابت .F۴ixed-W id‏ 


:USING NLS PARAMETERS 


يوفر الأوراكل مجموعة من العوامل يطلق عليها اسم National Language Supضمص0! (NS)‏ تساعد 
على تحديد أمور مختلفة عالمياً مثل طريقة حفظ وعرض التايخ.والتوقيت» الرمز المستخدم للعملة المحليةء 
اليوم الأول في الأسبوع (السبت عند المسلمين والاثنين عند الغري) وغيرها من الأمور. 


يمکن تحدید عوامل ال N18‏ بثلاث طرق هي: 


.Initialization Parameter File J| Jıدعت عبر‎ 
)Rهعایtار یستخدم في نظام الویندوز ال‎ ( Environment Va r1ھb1es باستخدام ال‎ 
.ALTER SESSION J ûلمج باستخدام‎ 


التعديل بواسطة جملة ۸L۲ ER SESS10N‏ ھو الأقوی ثم یلیھ استخدام Environment J|‏ 
aris‏ . هذا يعني اذا تم تعدیل أحد العوامل بواسطة ال ]nitialization Par 4me) ۴1e‏ وبواسطة 
جملة ER SESSION J‏ "1 » فإن قيمة العامل تكون هي المحددة بجمل ALTER SESSION J‏ 
وليس القيمة المحددة بJl Parameter File‏ izationاnitia!‏ أو القيمة المحددة بJl Environment‏ 
.Variables‏ 


ملاحظة: بعض العوامل لا تتغير باط Environment ÛJ مlدختwlڊ Î ALTER SESSION‏ 


. Variables 


تذکر: جاء ذکر ال Environment Vھrنھط [6s‏ في الفصل الثالث. 
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:NLS Parameters 
يوفر الأوراكل عدد من العوامل منها:‎ 


1S_LANGUAGEاN:‏ يستخدم في عرض اسماء الأيام والشهور» ويستخدم لعرض الرموز 
الخاصة بالتوقيت والتاريخ مثل قبل أو بعد الميلاد ( 80 ,5 ۸) أو التوقیت (۸۷1 )۶M,‏ › ویستخدم 
كلغة الرسائل المعروضة في الأوراكل مثل رسائل الأخطاء "عع ھیوم۷1 "٤۲۲٥۲‏ › ويستخدم ايضاً 
في تحديد نوعية عملية .Sorting ÛJI‏ 


› يستخدم في تحديد طريقة عرض التاريخ » واختيار رمز للعملة المحلية‎ :Nا1S_"‎ ERR" RY 
.190 تحديد أول يوم في الأسبوع وتحديد قيم تعرف باسم قيم ال‎ 


.NLS_LANG ° 


تشمل NLS LANGUAGE Û‏ قیم ال u1‏ هfەD‏ للعوامل التالية: 


N18 DAE_ LANGUAGE‏ : لتحديد اسماء الشهور والأيام والإختصارات المعمول بها (مثل 
اختصار يوم الإثنين بالغة الإنجليزية .({(MON‏ 

:N1S_S0R١ ٠‏ لتغيير طريقة تزتيب البيانات "ع«ذ٤إهS"‏ في الأوراكل › مثلاً اذا تم تحدید قيمتها 
بالتاڵي NHS=SORT =6Ger ı41‏ فان ترتيب البيانات سوف يكون طبقاً للأبجدية الألمانية. 


أما ال N18 "ERR ORY‏ فتشمل قيم 10ں وء( للعوامل التالية: 


S_CURRENCYاN:‏ لإختيار رمز للعملة المحلية. 

:N1.8_1S0_)RRENCY‏ لإختيار رمز مخيّطر لعلية البلد مثل 105 للدولار الأمريكي. 
:N1._ DA E_FORMAT‏ لتحديد طريقة عرص رالتاريخ» مثلاً الأيام ثم الشهور ثم السنين. 
5_NUMERIC_CHARACTERSاN:‏ لتحديد طريقة عرض الأرقام التي تحوي على 
فواصل مثل الأرقام الغير صحيحة (مثل 222.44.5). 


المقصود بأن العامل R۷‏ ۸1۲0 ۸ 1S_1اN‏ يشمل القيم ال [٤‏ وء( للعوامل الأخرى › بذلك هو عند 
تحدید قيمة ال ۸1۲0۸۷ N1.5_1 E۸‏ » فليس من الضروري تحديد قيم العوامل التي يشملها. 

أيضاً في حالة تحديد العامل ۸1۲0۸۷ N1. 1 ٤R۸‏ والعوامل التي يشملها › يتم تغيير قيم العوامل التي 
يشملها« حيث أن تغيير قيمة العامJ NLS TERRITORY‏ يتم فقط في Environment Variaۆb]es Û|‏ 
أو عبر جملة ال ٤R S٤SS10 ٩‏ ۸1۲ مما يجعله النوع الأقوى من العوامل التي يشملها التي تتغير 

جميع الطرق. مثال على ذلك اذا تم تحديد قيمة العامل N1.) R۸ REN ٣¥‏ بالقيمة £ (الباوند) في ال 
Parameter File‏ iationاnifia]‏ ولكن ايضاً تم تحديد قيمة العملة المحلية في 

N18" ERRITORY‏ بالقيمة ¥ (الين الياباني) فإن رمز العملية المحلية في الأوراكل يكون الين الياباني. 


:NLS_ LANG Parameter 
ویتم تحدیدھا فقط عبر استخدام ال‎ N19_].۸ N6 يمكن استخدام قيم مختلفة لکل مستخدم باستخدام ال‎ 
Character s Territory s Language ıھ‎ plnقl تتكون من ثلاث‎ .Environment Variables 


Se)‏ معرفة بالقاعدة التالية: 


NLS_LANG = Langugae_Territory.Charset 
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في القاعدةء 


guage‏ anا:‏ هي موازية للعامل N18 LANGUAGE‏ ویتم تعریف قیمتھا في الأوراکل عند 
تحدید ها ولا یتم الأخذ بقیمة N1 S_ L۸ N6 [۸6۴٤‏ › اذ یعتبر العامل N1,9_1.۸ NG‏ هو الأقوی 
في الأوراكل. 

:rerritory‏ هي موازية للعامل N15 ٤R R۲0‏ ويتم تعريف قيمتها في الأوراكل عند 
تحدید ها ولا يتم الأخذ بقيمة 08¥ N1 S_ ٤R R17‏ »اذ يعتبر العامل NS 14۸ N6G‏ هو 
الأقوى في الأوراكل. 

:Charse)‏ يحدد نوعیة ال Character Se)‏ للمستخدم فقط, 


:NLS and Functions 


خلال دراستك للإمتحان الأول "1ntrodu ction t٥ SQ"‏ استخدمت ال NS Parameters‏ داخل 
عمليات متعددة مثل جملة ١ 10_٤8 ۸R‏ وللتذكير راجع المثال 10.1. 


مثال تطبيقي 10.1: 


SELECT TO_CHAR (hire date, $DD.Mon.YYYY’, 
‘NLS DATE LANGUAGE => GERMAN’) 
FROM HR.EMPLOYEES 


يمكن استخدام العوامل التالية مغ ۸۴ :۲0_)€CBH‏ 


NLS_DATE_LANGUAGE 
NLS_NUMERIC_CHARACTERS 
NLS_CURRENCY 
NLS_ISO_CURRENCY 
NLS_CALENDAR 


يمكن استخدام العوامل التالية مع ۲0_(0۸1۴: 
NLS_DATE LANGUAGE °‏ 
NLS_CALENDAR °‏ 
يمكن استخدام العوامل التالية :TO_NUMBER ga‏ 
NLS_NUMERIC CHARACTERS °‏ 


NLS_ CURRENCY 
NLS_ISO_CURRENCY ° 
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:QUERYING INFORMATION 
:NاS للحصول على معلومات حول ال‎ 


Jاو‎ Character Set J| jE لومت‎ رgî‎ :NLS_DATABASE_PARAMETER 
.04غ4ط4e المستخدم في ال‎ Nationa] Character Set 


SELECT PARAMETER, VALUE 


FROM NLS_DATABASE_PARAMETER 
WHERE PARAMETER LIKE ‘%CHARACTERSET%’; 


:N18_1NSTANCE_PARAMETER °‏ توفر معلومات عن قيم عوامل ال N18‏ المحددة في 
.Initialization Parameter File Û!‏ 


1S_SESSI[ON_PARAMETERاN:‏ توفر معلومات عن قيم عوامل ال N18‏ المحددة لل 
Session‏ فقط, 


® 1D_VALUESاS_V۷AاŞN$:‏ توفر معلومات حول جميع القيم المتوفرة المسموح استخدامها 
لتحديد .Language, Territory, Character Set JI ùم J‏ 
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